我正在使用jQuery的ajax
方法向我的Elastic POST
API提出_search
请求。
在查询中传递参数时,一切都很好:
$.ajax({
url: '//localhost:9200/my_index/_search/?q=hello',
method: 'POST'
}).then(function(body){
console.log(body);
});
在正文中传递参数(json)时,问题就开始了:
$.ajax({
url: '//localhost:9200/my_index/_search/',
method: 'POST',
dataType: 'json',
contentType: "application/json",
data: this.params
}).then(function(body){
console.log(body);
});
浏览器(Chrome)不会发送POST
请求,而是发送OPTIONS
请求。
阅读jQuery的文档,我看到了:
对于跨域请求,将内容类型设置为application / x-www-form-urlencoded,multipart / form-data或text / plain以外的任何内容将触发浏览器向服务器发送预检OPTIONS请求
这可能就是它的来源。
问题是,在预检请求之后没有任何反应。
在Wireshark中查看请求本身:
OPTIONS /my_index/_search/ HTTP/1.1
Host: localhost:9200
Connection: keep-alive
Cache-Control: max-age=0
Access-Control-Request-Method: POST
Origin: http://localhost:4000
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/49.0.2623.110 Safari/537.36
Access-Control-Request-Headers: accept, content-type
Accept: */*
Referer: http://localhost:4000/search/?q=hello
Accept-Encoding: gzip, deflate, sdch
Accept-Language: en-US,en;q=0.8,fr;q=0.6
HTTP/1.1 200 OK
Access-Control-Allow-Origin: *
Access-Control-Allow-Methods:
Access-Control-Max-Age: 1728000
date: Tue, 12 Apr 2016 07:30:50 GMT
content-length: 0
我注意到响应的Access-Control-Allow-Methods
字段为空,所以我认为它可能是相关的。
我的 elasticsearch.yml 文件包含:
http.cors.enabled: true
http.cors.allow-origin: "*"
我补充说:
http.cors.allow-methods : OPTIONS, HEAD, GET, POST, PUT, DELETE
但它没有改变任何东西。