9

我有以下 jQuery AJAX 请求:

// collect form data and create user obj
var user = new User();
user.firstname =  $("#usrFirstName").val();
user.lastname =  $("#usrSurname").val();
user.role =  $("#usrRole").val();

// actual ajax request
$.ajax({
    type: 'POST',
    url : 'http://awesome-url',
    crossDomain: true,
    data: user,
    contentType:"application/json; charset=utf-8",
    dataType: 'json'
}).done(function(data, status) {
    alert(JSON.stringify(data));
}).fail(function(data, status) {
    alert(status);
    alert(JSON.stringify(data));
});

来自服务器的响应是:

""status":400,"statusText":"Bad Request"
"客户端发送的请求语法错误。"

服务器正在运行 Spring-MVC。但据我所知,它工作正常。因为如果我使用 Postman 和以下配置手动发送请求,它就可以工作。

标题:

Content-Type application/json; charset=utf-8

内容:

{"firstname":"alex","lastname":"lala","role":"admin"}

不得不提的是,它是一个跨域请求(开发的时候会和服务器托管在同一个域上)。我确实禁用了浏览器中的安全设置,并且对服务器的 AJAX 请求工作正常(只要我不必发送数据)。

4

1 回答 1

9

你需要序列化你的json,试试:

$.ajax({
    type: 'POST',
    url : 'http://awesome-url',
    crossDomain: true,
    data: JSON.stringify(user),
    contentType:'application/json; charset=utf-8',
    dataType: 'json'
})
于 2013-10-23T17:34:21.037 回答