ajax的跨域问题解决

在被请求的php文件里增加:

header(“Access-Control-Allow-Origin: *”);
header(“Access-Control-Allow-Methods”, “POST,OPTIONS,GET”);

另外:

在chrome浏览器或者firefox浏览器里,由于安全限制的原因,本地调试JS,如果不配服务器环境而直接打开页面,那所有的AJAX操作会抛出下面错误:

XMLHttpRequest cannot load file:///D:/file.html. Origin null is not allowed by Access-Control-Allow-Origin.

Origin null is not allowed by Access-Control-Allow-Origin. 的意思就是由于安全原因浏览器不允许跨域访问。

chrome、firfox、opera都出现了这种情况,因为有安全沙箱,它们认为加载本地其它html文件为跨域访问。但是使用IE8就不会出现这种错误,很多人不是很理解。

这里Windows help and support 做出了解释 IE本身也并不是允许跨域的因为这样很不安全,但是如果不跨域的话又带来很多不便,所以会让你手动的选择一下是否允许跨域。而chrome、firfox、opera则默认就是不允许。

另外:

CORS的一篇文章:

https://developer.mozilla.org/en-US/docs/HTTP/Access_control_CORS

另外:

如果脚本可以和同域的php交互的话,可以使用php的curl等方式帮助传输数据。

另外:

感谢磊哥和其他小伙伴的帮忙。

原文链接:,转发请注明来源!

发表评论