PHP Ajax 跨域问题最佳解决方案
2015-09-18 16:33
746 查看
本文通过设置Access-Control-Allow-Origin来实现跨域。
参考网址:http://www.runoob.com/w3cnote/php-ajax-cross-border.html
例如:客户端的域名是client.runoob.com,而请求的域名是server.runoob.com。
如果直接使用ajax访问,会有以下错误:
在被访问的页面添加如下代码,该页面就可以被不同域名访问了。
参考网址:http://www.runoob.com/w3cnote/php-ajax-cross-border.html
例如:客户端的域名是client.runoob.com,而请求的域名是server.runoob.com。
如果直接使用ajax访问,会有以下错误:
XMLHttpRequest cannot load http://server.runoob.com/server.php. No 'Access-Control-Allow-Origin' header is present on the requested resource.Origin 'http://client.runoob.com' is therefore not allowed access.
在被访问的页面添加如下代码,该页面就可以被不同域名访问了。
1、允许单个域名访问
指定某域名(http://client.runoob.com)跨域访问,则只需在http://server.runoob.com/server.php文件头部添加如下代码:header('Access-Control-Allow-Origin:http://client.runoob.com');
2、允许多个域名访问
指定多个域名(http://client1.runoob.com、http://client2.runoob.com等)跨域访问,则只需在http://server.runoob.com/server.php文件头部添加如下代码:$origin = isset($_SERVER['HTTP_ORIGIN'])? $_SERVER['HTTP_ORIGIN'] : ''; $allow_origin = array( 'http://client1.runoob.com', 'http://client2.runoob.com' ); if(in_array($origin, $allow_origin)){ header('Access-Control-Allow-Origin:'.$origin); }
3、允许所有域名访问
允许所有域名访问则只需在http://server.runoob.com/server.php文件头部添加如下代码:header('Access-Control-Allow-Origin:*');
相关文章推荐
- MapReduce 规划 六系列 MultipleOutputs采用
- Laravel的安装
- php的会话管理
- PHP编程规范
- Laravel5 打印SQL
- php面向对象编程之构造方法 __construct()
- PHP使用curl伪造IP地址和header信息
- php简易计算器
- 转 ffmpeg+sdl rstp 播放
- lnmp php重启没有加载正确php.ini文件
- php的apc扩展浅析(四)
- 转 rtp rstp
- lftp命令详解
- PHP环境部署问题集合
- PHP学习笔记一
- PhpStorm8 无法使用 svn 的解决办法
- php的常量
- PHP实现异步调用方法研究
- [Zend Mail]发送中文名附件出现乱码解决方案
- ubuntu安装及配置vsftpd