我在本地环境中安装了ES5.4,我尝试使用ajax请求(使用jQuery)从我的Web浏览器向API发出请求,CORS策略破坏了它。
我阅读了ES HTTP文档和一些论坛,但我无法解决我的问题。
下面是我的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)}
);
这是来自浏览器的结果:Code POST 200 OK
在浏览器网络工具中,我在结果中得到了一些对象,这很好,但我的 JavaScript 代码将 ajax 结果读取为失败:
"
xhr.status文本:"错误"
成功:空
你能帮我在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
crossDomain:真的,
并从 .yml 中删除:
http.cors.allow方法:X请求,内容类型,内容长度
我收到以下消息:
无法加载 http://localhost:9200/_search:请求的资源上不存在“访问控制允许源”标头。因此,不允许访问源“http://localhost:90”。
这是相应的响应标头:
HTTP/1.1 200 OK警告:299 Elasticsearch-5.6.3-1a2f265“不推荐对rest请求进行内容类型检测。请使用[Content type]标头指定内容类型。”“2017年11月7日星期二11:51:24 GMT”内容类型:application/json;charset=UTF-8内容编码:gzip内容长度:6898
插入内容类型后(已经测试过):
content type:" application/JSON;charset=UTF-8”,
我收到这个新错误:
无法加载http://localhost:9200/_search:对预检请求的响应未通过访问控制检查:请求的资源上不存在“Access-Control-Allow-origin”标头。因此,现在允许访问源“http://localhost:90”。
但我的elasticsearch.yml包含:
http.cors.allow-来源:"*"http.cors.enabled:true
最终我解决了我的问题!感谢ADyson的支持;)
这是我的超文本传输协议配置(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);
}
});
在我的html页面中,我在一个容器div中有两个div。两个内部div有一个“position:aboslute”。因为它们必须被放置在集装箱div的左下角。 当容器div只有一个内部div时,这非常有效。但是当我添加第二个div时,第二个div会被放置在第一个内部div的顶部。这当然有道理。但现在我正试图找到一种方法,让它们彼此相邻,而不是相互重叠。 生成内部div。所以我不能手动为它们添加ID
我这里出了点状况。几个星期以来我一直试图解决这个问题。我是使用iReport的新手。 这些天我在为公司的一个部门设计一份报告。
我正在尝试理解Spring boot中的松散绑定我已经查看了https://docs . Spring . io/Spring-boot/docs/current/reference/html/boot-features-external-config . html # boot-features-external-config-relaxed-binding但是我认为我缺少了一些东西如果我有一个
问题内容: 我在端口5000的node.js服务器上设置了CORS,如下所示: 我现在正尝试像这样在从硬盘打开的静态网页中使用JQuery发送AJAX POST请求: 该函数从不调用,并且我得到的唯一警报是来自XHR 处理程序的警报,其中包含以下错误: 我认为CORS配置合理, 我缺少什么? 编辑 :对于我而言,我能找到的最佳解决方案是从服务器发送页面: 问题答案: 这是我正在使用的代码。它位于我
问题内容: IE11由于某种原因拒绝了PUT请求,但仅当我使用https时。我很难找到问题,因为使用http,localhost和其他浏览器可以正常工作。 控制台显示两个错误 从浏览器发送的OPTION请求是 服务器的响应如下: AngularJS用于客户端标准$ http PUT。服务器端使用带有jersey的Java,请求过滤器来处理CORS如下: 也许您可以看到问题所在。 谢谢 问题答案:
我有Vuejs前端和一个Spring Boot Webflux控制器。现在浏览器在调用Spring Boot时会与CORS抱怨。 你知道为什么上面链接中描述的CORS配置不起作用吗?我还尝试在全局配置上启用CORS,并使用WebFilter启用CORS。但似乎什么都不管用。