gpt4 book ai didi

javascript - 跨域 GET 与 Marklogic 服务器端 js 应用程序

转载 作者:行者123 更新时间:2023-11-29 23:46:00 26 4
gpt4 key购买 nike

这里有很多问题涉及跨域请求、CORS、 header 等。我几乎尝试了所有我能找到的方法,但无济于事。 MarkLogic 文档中可能有关于此的内容,但我在那里浪费了几个小时,而且很难导航。也没有任何 MarkLogic 示例可以遵循(我已经能够找到)。

[Error] Origin http://localhost:8010 is not allowed by Access-Control- Allow-Origin.
[Error] Failed to load resource: Origin http://localhost:8010 is not allowed by Access-Control-Allow-Origin. (my-js.sjs, line 0)
[Error] XMLHttpRequest cannot load http://localhost:8004/my-js.sjs due to access control checks.

我会尽量包括所有相关信息,但如果我遗漏任何信息,请告诉我。

我在安装了 MarkLogic 9 的 Safari 上运行 Mac OS X。我在端口 8004 上设置了一个 http 应用程序服务器。我还有一个在端口 8010 上运行的 python SimpleHTTPServer。我有一个简单的 html 站点和一个包含以下简单 GET 请求的 js 脚本

$("#http-button").click(function(){
console.log("clicked");
$.get("http://localhost:8004/my-js.sjs",function(data,status){
alert("Data: " + data + "\nStatus" + status);
$("#http-results").text(data);
})
});`

我的服务器端脚本 my-js.sjs 只是一个简单的查询。我已经包含了我认为是允许跨域请求的必要 header ,但它仍然不起作用。

//xdmp.setResponseContentType("text/plain");
xdmp.setResponseContentType("application/json");
xdmp.addResponseHeader('Access-Control-Allow-Origin', '*');
xdmp.addResponseHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');
xdmp.addResponseHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');
xdmp.addResponseHeader('Access-Control-Allow-Credentials', true);

var jsearch = require('/MarkLogic/jsearch.sjs');
//query and print
jsearch.documents()
.where(
cts.wordQuery("cardiac")
).slice(0,3).result();

我不知道从这里去哪里。我的实现依赖于能够执行跨域请求。我能够使用 node.js 和 REST 服务器来完成它,但我无法弄清楚如何使用服务器端 JavaScript 来完成它,这对我的目的来说要快得多。

我也乐于接受新的实现想法,但我已经编写了很多服务器端 JavaScript,所以我不想重新开始。

最佳答案

好吧,对不起,如果我浪费了任何时间。原来这些 header 起到了作用,我只是没有放 是的

在引号中。

关于javascript - 跨域 GET 与 Marklogic 服务器端 js 应用程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44122501/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com