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

本文经过设置Access-Control-Allow-Origin来实现跨域。php

例如:客户端的域名是edu.jb51.net,而请求的域名是edu.jb51.net。html

若是直接使用ajax访问,会有如下错误:linux

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.

容许单个域名访问ajax

指定某域名(http://edu.jb51.net)跨域访问,则只需在http://edu.jb51.net/server.php文件头部添加以下代码:跨域

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

容许多个域名访问.net

指定多个域名(http://edu.jb51.net、http://edu.jb51.net等)跨域访问,则只需在http://edu.jb51.net/server.php文件头部添加以下代码:server

$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);      
}

容许全部域名访问htm

容许全部域名访问则只需在http://edu.jb51.net/server.php文件头部添加以下代码:get

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

 

本文地址:https://www.linuxprobe.com/php-ajax-cross.html域名

相关文章
相关标签/搜索