首页 > 开发 > PHP > 正文

PHP实现服务器端允许客户端ajax跨域

2024-05-04 22:02:12
字体:
来源:转载
供稿:网友

本文主要讲述的是用PHP实现服务器端允许客户端ajax跨域 ,有需要的朋友可以参考一下。

解决跨域的关键是设置 Access-Control-Allow-Origin。

例如:客户端的域名是 api.itbsl.com,而请求的域名是www.itbsl.com

如果直接使用ajax访问,会有以下错误:本篇文章主要讲述的是

XMLHttpRequest cannot load http://www.itbsl.com/server.php. No 'Access-Control-Allow-Origin' header is present on the requested resource.Origin 'http://api.itbsl.com' is therefore not allowed access.

1.允许单个域名访问

指定某域名http://api.itbsl.com跨域访问,则只需在http://www.itbsl.com/server.php文件头部添加如下代码:

header('Access-Control-Allow-Origin:http://api.itbsl.com');

2.允许多个域名访问

指定多个域名 http://api.itbsl.com、http://doc.itbsl.com等 跨域访问,则只需在http://www.itbsl.com/server.php文件头部添加如下代码:

  1. $origin = isset($_SERVER['HTTP_ORIGIN'])? $_SERVER['HTTP_ORIGIN'] : '';   
  2.  
  3. $allow_origin = array(   
  4.  
  5.     'http://api.itbsl.com',   
  6.  
  7.     'http://doc.itbsl.com'  
  8.  
  9. );   
  10.  
  11. if(in_array($origin$allow_origin)){   
  12.  
  13.     header('Access-Control-Allow-Origin:'.$origin);        
  14.  

3.允许所有域名访问

允许所有域名访问则只需在http://www.itbsl.com/server.php文件头部添加如下代码:

header('Access-Control-Allow-Origin:*');

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表