PHP跨域问题解决方案

首先,我们要明白什么是跨域:
跨域,指的是浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,是浏览器施加的安全限制。

浏览器的同源策略:
同源是指,域名,协议,端口均相同,有任一不相同皆将造成跨域

明白了这些,我们来说说解决跨域问题的两种方案
1,header设置允许跨域(推荐)
     后端代码设置:
          

//  指定允许其他域名访问
header('Access-Control-Allow-Origin:*');
// 响应类型
header('Access-Control-Allow-Methods:GET, POST, OPTIONS');
// 响应头设置
header('Access-Control-Allow-Credentials:false');


      
      前端ajax内设置:
        

$.ajax({
     type: "POST",
     crossDomain: true,   //允许跨域请求
     ...
     ...
     ...
})


2,代理
比如www.aaa.com/index.html  需要调用  www.bbb.com/index.php。可以写接口www.aaa.com/index.php来请求 www.bbb.com/index.php,
在让www.aaa.com/index.html直接请求www.aaa.com/index.php, 相当于自己做了代理访问,这样不经过浏览器自然不会有同源限制

3,nginx反向代理
    可以自行查阅下资料
4,前端vue的webpack代理
    可以自行查阅下资料

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值