本文通過設置Access-Control-Allow-Origin來實現跨域。

例如:客戶端的域名是client.youj.com,而請求的域名是server.w3cschool.cn。

如果直接使用ajax訪問,會有以下錯誤:

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

1、允許單個域名訪問

指定某域名(http://client.youj.com)跨域訪問,則只需在http://server.youj.com/server.php文件頭部添加如下代碼:

header('Access-Control-Allow-Origin:http://client.youj.com');

2、允許多個域名訪問

指定多個域名(http://client1.youj.com、http://client2.youj.com等)跨域訪問,則只需在http://server.youj.com/server.php文件頭部添加如下代碼:

$origin = isset($_SERVER['HTTP_ORIGIN'])? $_SERVER['HTTP_ORIGIN'] : '';  
  $allow_origin = array(  
    'http://client1.youj.com',  
    'http://client2.youj.com'  );  
  if(in_array($origin, $allow_origin)){  
    header('Access-Control-Allow-Origin:'.$origin);       }

3、允許所有域名訪問

允許所有域名訪問則只需在http://server.youj.com/server.php文件頭部添加如下代碼:


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