我通过AJAX发送到我的服务器nodejs,在客户端使用这个JS:
function login(){
var array=[];
var jsonData={};
jsonData.user=$('#user').val();
jsonData.pass=$('#pass').val();
array.push(jsonData);
console.log(JSON.stringify(array));
$.ajax({
method:'POST',
url: 'auth',
dataType: 'application/json',
data: JSON.stringify(array)
}).done(function(msg){
alert( "Data Saved: " + msg );
});
}
您可以看到,在发送ajax之前,浏览器输出控制台是:
[{"user":"User001","pass":"SecretPassword"}]
在服务器端,我有这段代码:
router.post('/', function(req, res, next){
console.log(req.body);
// { '[{"user":"User001","pass":"SecretPassword"}]': '' }
console.log(JSON.parse(req.body));
// {"[{\"user\":\"User001\",\"pass\":\"SecretPassword\"}]":""}
res.sendStatus(202);
}
但是,如果我使用Postman测试此Web服务,我的服务器会正确接收Json数据: Screen capture
拜托,有没有人帮助过我?,我试着解决这个问题大约2天:(
答案 0 :(得分:0)
不要对数据进行字符串化,它应该是一个对象,所以你可以直接发送jsonData:
function login(){
var array=[];
var jsonData={};
jsonData.user=$('#user').val();
jsonData.pass=$('#pass').val();
array.push(jsonData);
console.log(JSON.stringify(array));
$.ajax({
method:'POST',
url: 'auth',
dataType: 'application/json',
data: jsonData // << here
}).done(function(msg){
alert( "Data Saved: " + msg );
});
}
答案 1 :(得分:0)
var invoiceJson = {name:“ abc”};
$.ajax({
url: url,
type: "POST",
dataType: "json",
contentType: 'application/json; charset=utf-8',
data: JSON.stringify(invoicejson),
success: (data) => {
try {
console.log( data);
} catch (err) {
console.log( err);
}
}
})