入门客AI创业平台(我带你入门,你带我飞行)
博文笔记

Access-Control-Allow-Origin:ajax 跨域访问

创建时间:2015-12-02 投稿人: 浏览次数:1414

在使用jquery的$.ajax跨域访问的时候,如客户端域名是www.test.com,而服务器端是www.test2.com,在客户端通过ajax访问服务器端的资源将会报跨域错误:

XMLHttpRequest cannot load http://www.test2.com/test.php. No "Access-Control-Allow-Origin" header is present on the requested resource.Origin "http://www.test.com" is therefore not allowed access.

ajax跨域访问的解决方法很多,很多人推荐JSONP方法,这种方法只支持GET方式,不如POST方式安全。有兴趣的可以自行搜索,这里讲另外一种方法。

这时候只要在被请求的响应头中加入下面语句:

// 指定允许其他域名访问  
header("Access-Control-Allow-Origin:*");  
// 响应类型  
header("Access-Control-Allow-Methods:POST");  
// 响应头设置  
header("Access-Control-Allow-Headers:x-requested-with,content-type");  

就可以实现跨域请求了。

Access-Control-Allow-Origin:* 表示允许任何域名跨域访问

如果需要指定某域名才允许跨域访问,只需把Access-Control-Allow-Origin:*改为Access-Control-Allow-Origin:允许的域名

eg:header("Access-Control-Allow-Origin:http://www.test.com");



声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。