案例:PHP Ajax 跨域最佳解決方案
阿新 • • 發佈:2019-01-26
本文通過設定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:*');