Wro*_*ski 19 javascript fetch express body-parser
目标:在函数中从HTML发送一些定义的字符串数据,fetch()例如“我的数据”
我的代码:
HTML
<!DOCTYPE html>
<html>
<body>
<script type="text/javascript">
function fetcher() {
fetch('/compute',
{
method: "POST",
body: "MY DATA",
headers: {
"Content-Type": "application/json"
}
}
)
.then(function(response) {
return response.json();
})
.then(function(myJson) {
console.log(myJson);
});
}
</script>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
服务器.js
var express = require("express");
var app = express();
var compute = require("./compute");
var bodyParser = require("body-parser");
//not sure what "extended: false" is for
app.use(bodyParser.urlencoded({ extended: false }));
app.post('/compute', (req, res, next) => {
console.log(req.body);
var result = compute.myfunction(req.body);
res.status(200).json(result);
});
Run Code Online (Sandbox Code Playgroud)
当前: console.log(req.body)日志{}
期望: console.log(req.body)日志"MY DATA"
笔记:
body: JSON.stringify({"Data": "MY DATA"})但得到相同的空 {}Ale*_*sky 18
除了您当前的 bodyParser app.use() 之前,添加以下行:
app.use(bodyParser.json());
Run Code Online (Sandbox Code Playgroud)
这将使bodyParser能够解析application/json.
希望这有帮助!
一旦我弄清楚了什么bodyParser.urlencoded(来源:https : //www.npmjs.com/package/body-parser#bodyparserurlencodedoptions),我现在觉得有点愚蠢
返回仅解析 urlencoded 主体的中间件
解决方案
更改了fetch()请求,从:
body: "MY DATA",
headers: { "Content-Type": "application/json" }
Run Code Online (Sandbox Code Playgroud)
到
body: JSON.stringify({"Data": "MY DATA"}),
headers: { "Content-Type": "application/x-www-form-urlencoded" }
Run Code Online (Sandbox Code Playgroud)
这解决了问题!控制台记录:
{ '{"数据":"我的数据"}': '' }
| 归档时间: |
|
| 查看次数: |
11673 次 |
| 最近记录: |