PHP Ajax 跨域问题最佳解决方案
2015-12-26 17:57
721 查看
原文地址:http://www.runoob.com/w3cnote/php-ajax-cross-border.html
本文通过设置Access-Control-Allow-Origin来实现跨域。
例如:客户端的域名是client.runoob.com,而请求的域名是server.runoob.com。
如果直接使用ajax访问,会有以下错误:
指定某域名(http://client.runoob.com)跨域访问,则只需在http://server.runoob.com/server.php文件头部添加如下代码:
指定多个域名(http://client1.runoob.com、http://client2.runoob.com等)跨域访问,则只需在http://server.runoob.com/server.php文件头部添加如下代码:
允许所有域名访问则只需在http://server.runoob.com/server.php文件头部添加如下代码:
本文通过设置Access-Control-Allow-Origin来实现跨域。
例如:客户端的域名是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:*');
相关文章推荐
- FragmentPagerAdapter使用
- thinkphp中ajaxReturn方法实现ajax效果
- [知其然不知其所以然-14] cpu hotplug引出的cgroup故障
- OUTPUT 在insnert delete update 的神奇功效
- PHP表单详解
- yii用户注册表单验证实例
- php 解析ini配置文件
- php打印HTML
- php干货
- Php提交包含特殊字符的参数的方法
- 一段PHP SPL标准库的用法(遍历目录,查找固定条件的文件
- 什么是PHP
- <php+mysql>PHP脚本对数据库的基本操作,查找,删除,循环输出
- Weiphp随笔,百度天气API接口
- php【基础学习十】array数组
- 基于 ThinkPHP 3.2.3 的页面静态化功能的实现
- Awesome PHP
- PHP调用C#开发的dll类库方法
- 有用的网址(php)
- ThinkPHP之文件及文件夹复制