【发布时间】:2018-06-04 04:19:07
【问题描述】:
我正在尝试通过 XMLHttpRequest 传递参数并获得“未定义”-
客户:
var xj = new XMLHttpRequest();
var params = JSON.stringify({
PreviousTab: "cnn.com",
CurrentTab: "bbc.com"
});
xj.open("GET", "http://localhost:8080/api/traceTabs", true);
xj.setRequestHeader("Content-Type", "application/json");
xj.setRequestHeader ("Accept", "application/json");
xj.send(params);
服务器(Node.js):
app.get('/api/traceTabs', function (req, res) {
console.log('change url from ' + req.body.PreviousTab +
' to ' + req.body.CurrentTab); // return 'undefined'
});
server.js 配置(Node.js):
var express = require('express');
var app = express();
var bodyParser = require('body-parser');
var methodOverride = require('method-override');
var port = process.env.PORT || 8080;
app.use(bodyParser.json());
app.use(bodyParser.json({ type: 'application/vnd.api+json' }));
app.use(bodyParser.urlencoded({ extended: true }));
app.use(methodOverride('X-HTTP-Method-Override'));
app.use(express.static(__dirname + '/public'));
require('./app/routes')(app);
app.listen(port);
console.log('Listen to port ' + port);
exports = module.exports = app;
我尝试获取参数的所有选项都返回“未定义”:
req.body.PreviousTab / req.param('PreviousTab') 等等。
有人可以帮忙吗?
【问题讨论】:
-
能否添加中间件相关的服务器端代码
-
您需要 POST 或 PUT 才能发送参数 - 检查您的浏览器开发者工具网络选项卡,您会看到请求中没有发送任何参数
-
查看 XMLHttpRequest send() 的定义 -> xhr.spec.whatwg.org/#the-send()-method - 更准确地说是我之前的评论,对于 GET/HEAD 请求,发送正文被强制为空 - 所以,PUT/POST 方法是不是您可以使用正文发送的唯一方法 - 但是,它们是最常见的
标签: javascript node.js express xmlhttprequest