XmlHttpRequesterror:OriginnullisnotallowedbyAccess-Control-Allow-Origin

本文详细介绍了如何解决Chrome浏览器中AJAX请求不同域资源时遇到的‘Origin null is not allowed by Access-Control-Allow-Origin’错误。通过修改远程源代码或设置HTTP头,可以实现跨域资源共享(CORS)。

在Chrome浏览器中,如果想通过AJAX请求不同域中的资源,很可能就会遇到 “Origin null is not allowed by Access-Control-Allow-Origin” 的错误。

这是因为在新版本浏览器中安全策略引起。简单的说,如果XMLHttpRequest 请求的URL和当前页面不同一个域中时,浏览器会检测响应http header中有没有 Access-Control-Allow-Origin项,如果此项值为空或者与当前页面的域不匹配时,就会报此错误。

 

W3C标准中有个叫Cross Origin Resource Sharing (CORS)的东东用来解决此问题。

简单的说在目标资源返回的http头中需要包含有“Access-Control-Allow-Origin”项,并且其值格需要能匹配请求源页面域。

如在 http://a.com/default.html 页面中通过 ajax 获取 http://b.com/demo.aspx 页面的内容,那么响应http header中Access-Control-Allow-Origin就必须能匹配  http://a.com,否则就会出现以上错误。

添加此 http header的方法有几种:

 

$.ajax, $.post, $.get访问远程地址时可能报错:

 

XmlHttpRequest error: Origin null is not allowed by Access-Control-Allow-Origin

 

这是JS跨域访问产生的问题,解决办法要修改远程源代码:

 

1.请求的url指向PHP页面时,在PHP中添加 header("Access-Control-Allow-Origin: *");

 

2.html时,添加 <meta http-equiv="Access-Control-Allow-Origin" content="*">

### 配置CORS及使用Access-Control-Allow-Origin插件 #### 使用Chrome插件解决跨域问题 为了在开发环境中快速解决跨域问题,可以使用 `Allow CORS: Access-Control-Allow-Origin` 插件。安装完成后,可以通过配置自定义规则来指定允许访问的域名或IP地址。具体操作如下: 1. **安装插件** 访问 Chrome Web Store 页面下载并安装插件[^1]。 2. **配置插件** 打开插件选项页 (`Open options page`) 并进入 `Custom CORS rules` 设置部分。在此处输入目标服务的域名或IP地址,例如:`http://example.com` 或者通配符形式 `*` 表示允许所有来源的请求。 3. **启用插件** 在浏览器工具栏中找到插件图标并点击以激活它。一旦启动,插件会自动向HTTP请求头添加字段 `Access-Control-Allow-Origin: *` 来模拟服务器端支持跨域的行为。 #### Nginx服务器端配置跨域 如果希望永久解决问题而不是仅依赖于客户端插件,则需调整实际部署的服务器设置。以下是基于Nginx的一个典型例子: ```nginx server { listen 80; server_name example.com; location / { add_header 'Access-Control-Allow-Origin' '*'; add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS'; add_header 'Access-Control-Allow-Headers' 'Authorization'; if ($request_method = OPTIONS) { return 204; } proxy_pass http://backend_server; } } ``` 上述代码片段展示了如何通过修改Nginx配置文件让其返回合适的响应头部信息从而允许来自任何源(`*`) 的请求[^2] 。注意替换其中的占位符如 `example.com`, `backend_server` 等为你自己的真实值。 #### 谷歌跨域插件离线安装方法 对于某些特殊场景可能无法直接从网上商店获取最新版本时,还可以考虑手动加载.crx格式文件来进行本地化处理: 1. 下载对应平台架构下的压缩包; 2. 将解压后的目录拖拽至 chrome://extensions 地址栏内完成导入动作即可[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值