介绍一种不是通过js实现跨域的方式: 通过服务器端代理实现。
具体的思路:由于浏览器有同源策略限制,(同源策略即:https://developer.mozilla.org/zh-CN/docs/Web/Security/Same-origin_policy),所以想要跨域访问其他域下的资源,需要绕开浏览器的这个限制,可以在服务器端设置一个代理,由服务器端向跨域下的网站发出请求,再将请求结果返回给前端,成功避免同源策略的限制。
具体操作如下:
1、在localhost:81/a.html中,向同源下的某个代理程序发出请求
$.ajax({ url:‘/proxy.php?name=hello&info=information‘, //服务器端的代理程序 type:‘GET‘, success:function (){} })
2、在代理程序proxy.php中,向非同源下的服务器发出请求,获得请求结果,将结果返回给前端。
<?php $name=$_GET[‘name‘]; $info = $_GET[‘info‘]; $crossUrl = ‘http://b.com/sub?name=‘.$name; //向其他域下发出请求 $res = file_get_contents($crossUrl); echo $res; ?>
参考:http://www.ruanyifeng.com/blog/2016/04/cors.html
CORS与JSONP的使用目的相同,但是比JSONP更强大。
JSONP只支持GET
请求,CORS支持所有类型的HTTP请求。JSONP的优势在于支持老式浏览器,以及可以向不支持CORS的网站请求数据。
原文:http://www.cnblogs.com/dehuachenyunfei/p/6637445.html