AJAX 跨域解决方案 - CORS
AJAX 是无需刷新页面就能够从服务器去的数据的一种方法,负责Ajax运作的核心对象是XMLHttpRequest(XHR)对象。 同源策略是对XHR的一个主要约束,它为通信设置了“相同的域、相同的端口、相同的协议”这一限制。 这个方案叫做CORS(Cross-Origin Resource Sharing)跨源资源共享。
//弊端:存在浏览器兼容的问题
需要被请求方的服务端设置: Access-Control-Allow-Origin 切记:Access-Control-Allow-Origin 不可设置为 * ,设置为可访问的域名。 //设置可供访问的白名单 $white_list = ['http://cdn.abc.com','http://abc.com']; $_SERVER['HTTP_ORIGIN'] //表示请求方的域名 $http_origin = ''; if (!empty($_SERVER['HTTP_ORIGIN']) && in_array($_SERVER['HTTP_ORIGIN'],$white_list)) { $http_origin = $_SERVER['HTTP_ORIGIN']; //设置 header 信息 header("Access-Control-Allow-Origin: {$http_origin}"); header("Access-Control-Allow-Methods","POST,GET"); header('Access-Control-Allow-Credentials:true'); //允许访问Cookie header('Access-Control-Allow-Headers : X-Requested-With'); //设置Headers } //执行代码逻辑... 另:如果请求的是html,在文件里加上meta标签。 <meta http-equiv="Access-Control-Allow-Origin" content="*">
//弊端:不支持 POST 请求。 使用 JSONP 进行解决跨域问题,网上文章蛮多的。
与方案一类似。 修改Nginx Apache 配置: //Nginx http { ...... add_header Access-Control-Allow-Origin *; add_header Access-Control-Allow-Headers X-Requested-With; add_header Access-Control-Allow-Methods GET,POST,OPTIONS; ...... } Apache : <Directory /> ...... Header set Access-Control-Allow-Origin * </Directory> 大家可以根据自己的情况进行选择方案。 来源:http://mp.weixin.qq.com/s?__b... Thanks ~ AD:
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |