iis&nginx环境一次奇怪的跨域问题解决经过


跨域问题描述:

iis网站跨域、nginx 网站跨域 都已配置,访问接口依然出现跨域问题。


错误提示:

ccess to XMLHttpRequest at ‘https://xxx.com/gameapi/preserve/get/status’ from origin ‘https://cdn.xxx.com’ has been blocked by CORS policy: Response to preflight request doesn’t pass access control check: No ‘Access-Control-Allow-Origin’ header is present on the requested resource.


在这里插入图片描述


从上面这个报错可知,需要在api.xxx.com这个域名下,添加跨域请求来源 。

报错中看,配置的跨域来源Access-Control-Allow-Origin,value是’*, *',需要检查这个域名api.xxxx.com的Access-Control-Allow-Origin设置项。


原因分析:

(1)、iis http 响应标头已配置 Access-Control-Allow-Origin 值为*

在这里插入图片描述


(2)、niginx 响应标头已配置 Access-Control-Allow-Origin 值为*

在这里插入图片描述


以上均已配置 Access-Control-Allow-Origin 值为* ,可是为什么还会出现上面那个错误呢?

结合资料: https://www.cnblogs.com/hellxz/p/16208188.html 这篇解决类似跨域问题的文章中提到 ,原因是设置了2次重复跨域响应头问题。

由此,我们可能也是同样的原因,为了验证这个问题。


(3)、浏览器窗口中,单独访问接口 。

果然出现了 两条 Access-Control-Allow-Origin 值为* 的记录,如下图所示:

在这里插入图片描述


那根据错误就确定了问题的原因就是:Access-Control-Allow-Origin 响应头重复设置导致跨域设置失败。


解决方法: 保持跨域头Access-Control-Allow-Origin只有一个。


第一步,找到项目开发人员,确认是不是代码中 ,添加了解决跨域的响应头,回复是确定设置了:


在这里插入图片描述


既然代码已经设置,那就保留代码中的设置,我们只需要 调整 nginx 及 iis 环境中的 配置即可。

第二步,修改Nginx的配置,如下注释掉两行配置并reload

在这里插入图片描述


第三步,删除iis 跨域配置,删除后如下:

在这里插入图片描述


至此,问题得以解决。

  • 15
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

w风雨无阻w

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值