首页 > Web开发 > 详细

解决ajax跨域的办法,代理,cors,jsonp

时间:2018-02-02 21:34:36      阅读:354      评论:0      收藏:0      [点我收藏+]

技术分享图片

1、使用php做代理去请求第三方api接口

 

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

 技术分享图片

 

php做代理请求:

 技术分享图片

 

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

技术分享图片

 

请求结果:成功

 技术分享图片

 

 

将数据取出:

技术分享图片

 

结果:

技术分享图片

2、通过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域名文件:

技术分享图片

请求其他域名native.com:

 技术分享图片

 

请求的结果:成功

技术分享图片

3jsonp跨域

可以参考我的这篇文章:http://www.cnblogs.com/nosmoking/p/8407024.html

 

解决ajax跨域的办法,代理,cors,jsonp

原文:https://www.cnblogs.com/nosmoking/p/8407006.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!