我正在使用 jQuery 1.8.2 通过 jQuery 的 ajax POST 调用一些后端服务器 api。后端服务器和网页都在同一个域中。
在我的 js 文件中,我只是在调用$.post('/createAccount',data,function(e) { alert(e); });
在 Fiddler 中,此请求在 IE9 中作为 GET 发送。
GET http://[redacted]/createAccount HTTP/1.1
Accept: */*
Origin: [redacted]
Accept-Language: en-US
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; WOW64; Trident/5.0)
Host: [redacted]
Connection: Keep-Alive
Pragma: no-cache
使用 Chrome(最新)的同一页面在 Fiddler 中返回以下内容:
POST http://[redacted]/createAccount HTTP/1.1
Host: [redacted]
Connection: keep-alive
Content-Length: 103
Origin: http://[redacted]
X-Requested-With: XMLHttpRequest
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.4 (KHTML, like Gecko) Chrome/22.0.1229.79 Safari/537.4
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
Accept: */*
Referer: http://[redacted]/builder?token=[redacted]
Accept-Encoding: gzip,deflate,sdch
Accept-Language: en-US,en;q=0.8
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3
email=test123&token=[redacted]&company=tokentest1
这是使用 $.ajax 而不是 $.post 的代码(同样的问题):
$.ajax({
url : '/createAccount',
type : 'POST',
data : obj,
dataType : 'json',
cache: 'false',
success : function(data) {
if(data.status === 'ok') {
} else {
alert('error');
}
}
});