在被请求的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等方式帮助传输数据。
另外:
感谢磊哥和其他小伙伴的帮忙。
未经允许不得转载:天宝寺||陈瑞轩 » ajax的跨域问题解决