1. 程式人生 > >案例:PHP Ajax 跨域最佳解決方案

案例:PHP Ajax 跨域最佳解決方案

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

例如:客戶端的域名是edu.jb51.net,而請求的域名是edu.jb51.net。

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

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

允許單個域名訪問

指定某域名(http://edu.jb51.net)跨域訪問,則只需在http://edu.jb51.net/server.php檔案頭部新增如下程式碼:

header('Access-Control-Allow-Origin:http://edu.jb51.net');

允許多個域名訪問

指定多個域名(http://edu.jb51.net、http://edu.jb51.net等)跨域訪問,則只需在http://edu.jb51.net/server.php檔案頭部新增如下程式碼:

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

允許所有域名訪問

允許所有域名訪問則只需在http://edu.jb51.net/server.php檔案頭部新增如下程式碼:

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