使用ajax请求遇到的跨域问题

Posted 叶莜落

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用ajax请求遇到的跨域问题相关的知识,希望对你有一定的参考价值。

今天在使用ajax发请求的时候遇到如下问题:

以【Access-Control-Allow-Origin】为关键字搜索的结果进行改进,但没有效果。

返回仔细查看错误提示,发现ajax请求的url是localhost的,页面访问的是127.0.0.1,程序认为进行了跨域。

这里简单记录下怎么判断请求是跨域的。三个条件必须相同才不是跨域:①协议类型,如http和https就是不同的协议;②主机名;③端口号。

而我们在发送请求的时候,DNS总是将localhost解析为127.0.0.1,所以总认为localhost=127.0.0.1 。ajax为什么又认为它们不同呢?

于是在控制台中ping了一下localhost,发现竟然不是127.0.0.1 !

这篇文章 和 这篇文章给出了很好的解答。

那么我的问题其实也就很好解决了,访问的时候发送的请求也是localhost就可以了。经过验证,发现结果符合预期。

 

以上是关于使用ajax请求遇到的跨域问题的主要内容,如果未能解决你的问题,请参考以下文章

关于AJAX的跨域问题

逆向工程使用 Ext.Ajax.request 的跨域 POST 请求

Ajax请求的跨域(CORS)问题

使用AngularJS返回xml的跨域ajax请求

PHP解决mui中ajax的跨域问题

原生JS实现Ajax的跨域请求