XMLHttpRequest cannot load http://localhost:8080/api/test. Origin http://localhost:3000 is not allowed by Access-Control-Allow-Origin. 

我读过跨域ajax请求,了解底层的安全问题。在我的例子中,两台服务器在本地运行,并且喜欢在测试期间启用跨域请求。

localhost:8080 - Google Appengine dev server
localhost:3000 - Node.js server

当我的页面从节点服务器加载时,我发出ajax请求到localhost:8080 - GAE服务器。什么是最简单,最安全的(不想启动chrome禁用web-security选项)。如果我必须改变“内容类型”,我应该在节点服务器上这样做吗?如何?


当前回答

如果你使用快捷方式,

var express = require('express')
var cors = require('cors')
var app = express()
app.use(cors())

如果你正在使用app.use(express.json());在你的服务器文件中使用JSON有效负载来解析传入请求,并且是基于body解析器的,请记住在使用app.use(cors())代码行之后使用它。否则,可能会出现安全问题。 歌珥

其他回答

我接受@火箭危险品的答案,因为它让我找到了解决方案。我需要在GAE服务器上设置标头。我必须设置这些

"Access-Control-Allow-Origin" -> "*"
"Access-Control-Allow-Headers" -> "Origin, X-Requested-With, Content-Type, Accept"

仅设置“Access-Control-Allow-Origin”出错

Request header field X-Requested-With is not allowed by Access-Control-Allow-Headers.

同样,如果需要发送认证令牌,也要添加这个

"Access-Control-Allow-Credentials" -> "true"

同样,在客户端,设置withCredentials

这将导致2个请求发送到服务器,其中一个带有OPTIONS。认证cookie没有随它一起发送,因此需要在外部认证处理。

我遇到了这个问题,我遵循了php方面(设置头部)和react (axios withcredential =true)的所有推荐代码片段,但我无法摆脱这个错误。

在php中我有:

header("Access-Control-Allow-Origin: *");
header("Access-Control-Allow-Methods: PUT, GET, POST");
header("Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept");

最后,我注意到这些头文件没有出现在响应中。

响应应该是这样的:

显然,出于某种原因,我的vscode开始将文件保存为UTF8-BOM。结果,报头立即被发送,所有后续的header(..)语句都被忽略,因为报头已经被发送。

有两个有用的php命令可以检查这个问题:headers_list()和headers_sent()

notepad++是很好的查看文件编码,并切换到不同的编码:

使用dataType: 'jsonp',为我工作。

   async function get_ajax_data(){

       var _reprojected_lat_lng = await $.ajax({

                                type: 'GET',

                                dataType: 'jsonp',

                                data: {},

                                url: _reprojection_url,

                                error: function (jqXHR, textStatus, errorThrown) {

                                    console.log(jqXHR)

                                },

                                success: function (data) {

                                    console.log(data);



                                    // note: data is already json type, you just specify dataType: jsonp

                                    return data;

                                }

                            });





 } // function               

如果你使用快捷方式,

var express = require('express')
var cors = require('cors')
var app = express()
app.use(cors())

如果你正在使用app.use(express.json());在你的服务器文件中使用JSON有效负载来解析传入请求,并且是基于body解析器的,请记住在使用app.use(cors())代码行之后使用它。否则,可能会出现安全问题。 歌珥

如果有人正在寻找解决方案,如果您正在使用express,这里是快速解决方案。

const express = require('express')
const cors = require('cors')
const app = express()

1)使用NPM install cors—save

2) import it [require] const cors = require('cors')

3)使用它作为中间件app.use(cors())

详细的安装和使用cors。 就是这样,希望它能起作用。