方法1.通过PHP设置响应头允许跨域(CORS方式)

CORS(跨域资源共享,Cross-Origin Resource Sharing)定义一种跨域访问的机制,可以让AJAX实现跨域访问。CORS 允许一个域上的网络应用向另一个域提交跨域 AJAX 请求。实现此功能非常简单,只需由服务器发送一个响应头即可

header(“Access-Control-Allow-Origin:*”); // 允许任何来源
 header(“Access-Control-Allow-Origin:http://local.com”); //只允许来自域名http://local.com的请求

代码如下:

local.com域名文件:

request 解决跨域 如何解决跨域请求_总结解决跨域的三种方法


请求其他域名native.com:

request 解决跨域 如何解决跨域请求_request 解决跨域_02


请求的结果:成功

request 解决跨域 如何解决跨域请求_总结解决跨域的三种方法_03


方法2.使用php做代理去请求第三方api接口

php是可以跨域的,我们利用ajax请求本域名中的php文件,php再去请求第三方接口文件,从而达到跨域目的。

request 解决跨域 如何解决跨域请求_回调函数_04


php做代理请求:

request 解决跨域 如何解决跨域请求_php_05


ajax请求本域名php代理文件:

request 解决跨域 如何解决跨域请求_request 解决跨域_06


请求结果:成功

request 解决跨域 如何解决跨域请求_回调函数_07


将数据取出:

request 解决跨域 如何解决跨域请求_跨域_08


结果:

request 解决跨域 如何解决跨域请求_request 解决跨域_09


方法3.jsonp方法 只能get

浏览器只对XHR(XMLHttpRequest)请求有同源请求限制,而对script标签src属性、link标签ref属性和img标签src属性没有这这种限制,利用这个“漏洞”就可以很好的解决跨域请求。JSONP就是利用了script标签无同源限制的特点来实现的,当向第三方站点请求时,我们可以将此请求放在<script>标签的src属性里这就如同我们请求一个普通的JS脚本:

<script src="http://www.abc.com/index.php/?param1=1&callback=fnName"> </script>

JSONP实现跨域请求的原理简单的说,
就是动态创建<script>标签,然后利用<script>的src 不受同源策略约束来跨域获取数据。
JSONP 由两部分组成:
回调函数和数据。
回调函数是当响应到来时应该在页面中调用的函数。回调函数的名字一般是在请求中指定的。而数据就是传入回调函数中的 JSON 数据。

本站并提供一个回调函数来接收数据(函数名可约定,或通过地址参数传递)。

第三方网站产生的响应为json数据的包装(故称之为jsonp,即json padding),形如:

callback({“name”:“fegnjie”,“age”:“18”}),这样本站浏览器会调用callback函数,并传递解析后json对象作为参数。

第1步:动态创建<script>标签,设置其src,回调函数在src中设置:

request 解决跨域 如何解决跨域请求_php_10


第2步:在页面中,返回的JSON作为参数传入回调函数中,我们通过回调函数来来操作数据。

request 解决跨域 如何解决跨域请求_php_11

了解了JSONP的基本使用方法,我们在实现上面通过ajax调用豆瓣接口的需求,实现代码如下:

request 解决跨域 如何解决跨域请求_request 解决跨域_12


在控制台,我们可以查看到返回的response数据格式为JSON对象格式的,具体需要取出哪些参数,可以根据自己的需要:

request 解决跨域 如何解决跨域请求_跨域_13