跨域问题

php 解决跨域

  • 简单跨域问题
header("Access-Control-Allow-Origin: *");
header("Access-Control-Allow-Methods:POST");  

允许自定义请求头:方式一
header("Access-Control-Allow-Headers:x-requested-with,content-type,xxx自定义请求头xx");  
  • 非简单跨域

非简单请求每次会发出两次请求,预检请求和正常请求

缓存预检命令1小时,取消options请求
header("Access-Control-Max-Age:3600"); 

当携带cookie时origin必须全匹配,不能使用*,而且要增加Access-Control-Allow-Credentials
$origin = $_SERVER['HTTP_ORIGIN'];
if(isset($origin)){//跨域时$origin不等于null
    header("Access-Control-Allow-Origin:$origin");
}

header("Access-Control-Allow-Credentials: true");//enable cookie

nginx 解决跨域

 server {
        listen 8090;
        server_name 127.0.0.1;
        root /var/www/public;
        index index.html index.php index.htm;
        location / {
        	proxy_pass http://localhost:8080/;
        	
        	add_header Access-Control-Allow-Methods * always;
        	add_header Access-Control-Max-Age 3600 always;
        	add_header Access-Control-Allow-Credentials true always;
			add_header Access-Control-Allow-Origin $http_origin always;
			add_header Access-Control-Allow-Headers $http_access_control_request_headers always;
			if ($request_method = OPTIONS){
                return 200;
			}
        }
    }
  • 反向代理----隐藏跨域
 server {
        listen 80;
        server_name 127.0.0.1;
        root /var/www/public;
        location / {
        	proxy_pass http://localhost:8081/;
        }
         location /ajaxserver {
        	proxy_pass http://localhost:8080/test/;
        }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值