- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 Express NodeJS 和 mysql 构建一个 REST API。我在使用 GET
和使用 req.params.value
以及使用 URL 参数传递值时完全没有问题。
现在我尝试使用 POST
将一些数据插入我的数据库。使用 POSTMAN 执行此操作没有任何问题,因为显然您可以设置要使用的 BODY 变量。但我在我的应用程序中意识到我将无法使用 POSTMAN 来执行此操作。我的问题(可能很愚蠢)是如何将这些 BODY 变量传递给我的 api?我是否仍然通过 url 将它们作为参数传递?如果是这样,我会使用 req.body.value
或 req.params.value
吗?这是我的 POST
代码:
// Add new record
router.post('/editablerecords/add', function (req, res) {
let qb_TxnID = req.body.txnid
let type = req.body.type;
let margin = req.body.margin;
if (!qb_TxnID || !type || !margin ) {
return res.status(400).send({ error:true, message: 'Please provide qb_TxnID, type, or margin' });
}
// res.send(qb_TxnID + ' ' + type + ' ' + margin);
connection.query("INSERT INTO pxeQuoteToClose SET ? ", { 'qb_TxnID': qb_TxnID, 'type': type, 'margin': margin }, function (error, results, fields) {
if(error){
res.send(JSON.stringify({"status": 500, "error": error, "response": null}));
//If there is error, we send the error in the error section with 500 status
} else {
res.send(JSON.stringify({ error: false, data: results, message: 'New record has been created successfully.' }));
//If there is no error, all is good and response is 200OK.
}
});
});
最佳答案
这取决于您如何发出请求,作为 XMLHttpRequest 调用还是通过表单,但在这种情况下它肯定不会使用参数。根据您的要求,这里有三个选项可将数据发送到您的 API,根据您的情况,我建议使用最后一个。
1 - 您可以使用表单并使操作指向您的端点。在这种情况下,您必须将 x-www-form-urlencoded 数据的 bodyParser 中间件添加到您的 Express 应用程序中。如果您使用body-parser
库就像 app.use(bodyParser.urlencoded([options]))
一样简单。数据将在req.body
中提供.
2 - 您可以发送网址中的所有数据,但在查询字符串中,而不是参数中。例如:https://yourapi.com/editablerecords/add?qb_TxnID=data_id&type=data_type&margin=data_margin
。所有数据都将在 req.query
中提供。目的。无需添加任何解析器。
3 - 最后但并非最不重要的一点是,我建议使用 XMLHttpRequest 将数据作为 json 正文发送。为了帮助您,您可以使用像 axios
这样的库。或fecth
但原理保持不变:您使用数据对象设置您的正文,然后在 req.body
上检索它。在你的API上。看到您的代码,我确实假设您正在使用主体解析器,但如果情况并非如此,您应该使用 app.use(bodyParser.json())
添加中间件.
希望我已经回答了您的问题并对您有所帮助。
关于javascript - Express Node JS POST。如何在不使用 url 参数的情况下向 req.body 添加值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52541144/
我是 Java 新手,这是我的代码, if( a.name == b.name && a.displayname == b.displayname && a.linknam
在下面的场景中,我有一个 bool 值。根据结果,我调用完全相同的函数,唯一的区别是参数的数量。 var myBoolean = ... if (myBoolean) { retrieve
我是一名研究 C++ 的 C 开发人员: 我是否正确理解如果我抛出异常然后堆栈将展开直到找到第一个异常处理程序?是否可以在不展开的情况下在任何 throw 上打开调试器(即不离开声明它的范围或任何更高
在修复庞大代码库中的错误时,我观察到一个奇怪的情况,其中引用的动态类型从原始 Derived 类型更改为 Base 类型!我提供了最少的代码来解释问题: struct Base { // some
我正在尝试用 C# 扩展给定的代码,但由于缺乏编程经验,我有点陷入困境。 使用 Visual Studio 社区,我尝试通过控制台读出 CPU 核心温度。该代码使用开关/外壳来查找传感器的特定名称(即
这可能是一个哲学问题。 假设您正在向页面发出 AJAX 请求(这是使用 Prototype): new Ajax.Request('target.asp', { method:"post", pa
我有以下 HTML 代码,我无法在所有浏览器中正常工作: 我试图在移动到
我对 Swift 很陌生。我如何从 addPin 函数中检索注释并能够在我的 addLocation 操作 (buttonPressed) 中使用它。我正在尝试使用压力触摸在 map 上添加图钉,在两
我设置了一个详细 View ,我是否有几个 Nib 文件根据在 Root View Controller 的表中选择的项目来加载。 我发现,对于 Nibs 的类,永远不会调用 viewDidUnloa
我需要动态访问 json 文件并使用以下代码。在本例中,“bpicsel”和“temp”是变量。最终结果类似于“data[0].extit1” var title="data["+bpicsel+"]
我需要使用第三方 WCF 服务。我已经在我的证书存储中配置了所需的证书,但是在调用 WCF 服务时出现以下异常。 向 https://XXXX.com/AHSharedServices/Custome
在几个 SO 答案(1、2)中,建议如果存在冲突则不应触发 INSERT 触发器,ON CONFLICT DO NOTHING 在触发语句中。也许我理解错了,但在我的实验中似乎并非如此。 这是我的 S
如果进行修改,则会给出org.hibernate.NonUniqueObjectException。在我的 BidderBO 类(class)中 @Override @Transactional(pr
我使用 indexOf() 方法来精细地查找数组中的对象。 直到此刻我查了一些资料,发现代码应该无法正常工作。 我在reducer中尝试了上面的代码,它成功了 let tmp = state.find
假设我有以下表格: CREATE TABLE Game ( GameID INT UNSIGNED NOT NULL, GameType TINYINT UNSIGNED NOT NU
代码: Alamofire.request(URL(string: imageUrl)!).downloadProgress(closure: { (progress) in
我是一名优秀的程序员,十分优秀!