背景
首先,我在 Node 上运行了一个 Restify 服务,当我使用 GUI HTTP 客户端时它运行良好。我只声明前面要强调的,这是一个以浏览器为中心的问题。如果需要服务器端的解决方案,那就是容纳浏览器......
以下是使用我的 Restify Web 服务和 GUI HTTP 客户端的 100% 功能 HTTP 请求和响应:
请求-
POST /appointments HTTP/1.1
Content-Type: application/json
Accept: application/json
Host: localhost:8085
Connection: close
User-Agent: Paw/2.1.1 (Macintosh; OS X/10.10.1) GCDHTTPRequest
Content-Length: 142
{
"eventName": "Fiesta Forever",
"time": "Fri Dec 19 2014 15:55:00 GMT-0600 (CST)",
"phoneNumber": "13125555555"
}
回应-
HTTP/1.1 201 Created
Access-Control-Allow-Origin: *
Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept
Access-Control-Allow-Methods: POST, GET, OPTIONS
Access-Control-Max-Age: 1000
Content-Type: application/json
Content-Length: 37
Date: Fri, 19 Dec 2014 23:01:29 GMT
Connection: close
{"message":"Alright Alright Alright"}
更重要的是,我的服务器创建了一个未来的 cron 作业,可以在我的服务器控制台中看到:
Created: Fri Dec 19 2014 14:55:00 GMT-0600 (CST)
问题
我的问题是我正在尝试为我的服务编写一个浏览器界面。当我尝试使用 Ajax 发出相同的 HTTP 请求时出现错误。我创建了以下发出 HTTP 请求的测试函数:
function testPost() {
var jsonBody = "{\"eventName\": \"Fiesta Forever\",\"time\": \"Fri Dec 19 2014 14:15:00 GMT-0600 (CST)\",\"phoneNumber\": \"13125555555\"}";
$.ajax({
url: 'http://localhost:8085/appointments',
accepts: 'application/json',
type: 'POST',
data: jsonBody,
contentType: 'application/json',
crossDomain: true,
headers: {
"Access-Control-Allow-Origin":true
}
});
}
然后,我在我的 iOS 模拟器中加载包含该函数的页面,并从 Safari 开发者控制台调用该函数。我收到以下错误:
编辑:删除请求标头后,我收到:
Failed to load resource: the server responded with a status of 406 (Not Acceptable)
服务器代码
这是我服务器上的代码。我从 Express 文档中获取了以下代码,因为它们是唯一似乎实际上为每个响应添加正确标题的解决方案:
//CORS
server.use(function(req, res, next) {
res.header("Access-Control-Allow-Origin", "*");
res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
res.header("Access-Control-Allow-Methods", "POST, GET, OPTIONS");
res.header("Access-Control-Max-Age", "1000");
next();
});
谁能帮我弄清楚如何使用携带和接收 JSON 的 $.ajax 发出跨域 HTTP 请求?