Elasticsearch CORS 绝望

Posted

技术标签:

【中文标题】Elasticsearch CORS 绝望【英文标题】:Elasticsearc CORS despair 【发布时间】:2018-04-19 15:22:33 【问题描述】:

我在本地环境中安装了 ES5.4,我尝试使用 ajax 请求(使用 jQuery)从我的 Web 浏览器向 API 发出请求,但 CORS 策略破坏了它。

我阅读了ES HTTP documentation 和一些论坛,但我无法解决我的问题。

这是我的 elasticsearch.yml http conf:

http.port: 9200
http.cors.allow-origin: "*"
http.cors.allow-methods: X-Requested-With, Content-Type, Content-Length
http.cors.enabled: true
network-host: localhost

这是我的请求参数:

// simple query string 
var queryFilter = 
  "query": 
    "match":  
      "id_opp":"OPP_4"
    
  
;

jQuery.support.cors = true;

$.ajax(
  type: "POST",
  url: "http://localhost:9200/_search",
  crossDomain: true,
  data: JSON.stringify(queryFilter),
  dataType: "json",
  success: function(data): console.log(data)
  , 
  error: function(xhr)console.log(xhr)
);

这是来自浏览器的结果:代码 POST 200 OK

在浏览器网络工具中,我在结果中得到了一些对象,这很好,但我的 javascript 代码将 ajax 结果读取为失败:

响应文本:"" xhr.statusText:"错误" 成功:空

您能帮我在我的 ajax 请求中获得成功结果吗?

她是我的回应:


    "took": 33,
    "timed_out": false,
    "_shards": 
        "total": 10,
        "successful": 10,
        "skipped": 0,
        "failed": 0
    ,
    "hits": 
        "total": 6,
        "max_score": 1.2438203,
        "hits": [
                "_index": "opportunites",
                "_type": "opportunity",
                "_id": "OPP_4-10_LT_26173_MCHE_002",
                "_score": 1.2438203,
                "_source": 
                    "@version": "1",
                    "id_opp": "OPP_4-10_LT_26173_MCHE_002",
                    "@timestamp": "2017-11-03T16:17:24.852Z",                    
                    "commune": "CHARPEY"
                
            ,
        ]


删除后使用 Chrome

跨域:真,

并从 .yml 中删除:

http.cors.allow-methods: X-Requested-With, Content-Type, 内容长度

我收到这条消息:

无法加载http://localhost:9200/_search:否 请求中存在“Access-Control-Allow-Origin”标头 资源。因此不允许使用原点“http://localhost:90” 访问。

这是对应的响应头:

HTTP/1.1 200 OK 警告:299 Elasticsearch-5.6.3-1a2f265“内容类型 不推荐检测休息请求。指定内容类型 使用 [Content-Type] 标头。" "2017 年 11 月 7 日星期二 11:51:24 GMT" 内容类型:应用程序/json; charset=UTF-8 内容编码:gzip 内容长度:6898

插入 contentType 后(已测试):

contentType: "application/json;charset=UTF-8",

我收到这个新错误:

无法加载http://localhost:9200/_search:对预检的响应 请求未通过访问控制检查:否 'Access-Control-Allow-origin' 标头出现在请求的 资源。因此,现在允许使用 Origin 'http://localhost:90' 访问。

但我的 elasticsearch.yml 包含:

http.cors.allow-origin: "*" http.cors.enabled: true

【问题讨论】:

crossDomain: true 对您没有帮助。即使没有跨域请求,这也会模拟一个跨域请求。阅读 jQuery ajax 文档以了解此选项是什么。真的,您只希望它用于测试/模拟目的。 但是无论如何,如果你得到 200 OK 响应,那么它不是 CORS 错误。如果出现 CORS 错误,您甚至不会得到响应。 (除非 200 是对飞行前 OPTIONS 请求的响应,而不是您的实际请求??在这种情况下,您应该在大多数浏览器中看到控制台错误。)。或者您的响应中的 JSON 可能无效 - 请让我们看看您的响应是什么样的? 感谢您的回复。是的,这是我的第二个想法:错误的回报。我会在几分钟内粘贴它:) 刚刚注意到http.cors.allow-methods: X-Requested-With, Content-Type, Content-Length 也没有任何意义。这应该指定 HTTP 方法的列表(例如 GET、POST、HEAD、OPTIONS 等),而不是其他允许的标头列表。请参阅elastic.co/guide/en/elasticsearch/reference/current/… 了解可用选项,以及此选项的默认设置。 您的示例也有语法错误:success: function(data): console.log(data) , 必须是 success: function(data) console.log(data) , 。不确定这是否反映了您的真实代码。 【参考方案1】:

我终于解决了我的问题!感谢您 ADyson 的支持 ;)

这是我的 http 配置(elasticsearch.yml):

http.port:9200
http.cors.allow-origin: "*"
http.cors.allow-methods: Origin, X-Requested-With, Content-Type, Content-length, Accept
http.cors.enabled: true

这是我请求弹性搜索数据的 JavaScript 代码:

jQuery.support.cors = true;
// execute request
$.ajax(
    type: "POST",
    url: "http://localhost:9200/_search",
    data: JSON.stringify(queryFilter), // elastic filter
    dataType: "json",
    contentType: "application/json;charset=UTF-8",
    processData: false,
    success: function(data) 
        console.log(data)
    ,
    error: function(xhr, ajaxOptions, thrownError) 
        console.log(xhr);
    
);

【讨论】:

以上是关于Elasticsearch CORS 绝望的主要内容,如果未能解决你的问题,请参考以下文章

Elasticsearch 安装

ReactiveSearch 的 Elasticsearch CORS 错误

ElasticSearch NEST笔记

Elasticsearch深入8

elasticsearch+moloch

linux常用命令总结