CORS(跨域资源共享)源验证失败解决方法

在web系统中,安全软件扫描经常会发现CORS(跨域资源共享)作为高危漏洞出现。本文提供用Nginx作为反向代理的解决方案。解决方式是在nginx.conf文件中做如下配置:

  set $cors "";
 if ($http_origin ~* "^http?://.*\.xxxx\.com$") {
      set $cors $http_origin;
 }
 more_set_headers 'Access-Control-Allow-Origin: $cors';
 more_set_headers 'Access-Control-Allow-Credentials: true';
 more_set_headers 'Access-Control-Allow-Methods: GET,POST,OPTIONS';
 more_set_headers 'Access-Control-Allow-Headers: token,Authorization,DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
 more_set_headers 'Access-Control-Max-Age: 86400';

注意:

1、“xxxx.com"是示例域名,按你实际用到的更改。如果有多个外部域名,则逐一按if方式处理。不建议用”*“来代替所有。

2、配置位置1:在http中所有server之前,但可能不生效。不生效则用配置位置2方式。

3、配置位置2:放在server中的location部分之前。如果很多server,可单独放在一个文件中(如nginx.cors.item),在配置位置用下面语句引入:

#跨域配置
include /usr/local/nginx/conf/nginx.cors.item;

4、在location不要配置add_header,否则本处配置不生效。

这篇文章如果对您有所帮助或者启发的话,帮忙关注或点赞,有问题请评论,必有所复。您的支持是我写作的最大动力!

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
CORS(Cross-Origin Resource Sharing)是一种机制,用于允许在一个域名下的Web应用程序访问另一个域名下的资。默认情况下,浏览器会限制跨域请求,以防止恶意的行为。但是,使用CORS服务器可以通过在响应头中包含特定的标头来指示浏览器允许跨域请求。 要启用CORS服务器需要在响应头中包含一些特定的标头字段。其中最常见的是"Access-Control-Allow-Origin",它指定了允许访问资服务器可以设置这个字段为特定的域名,或者使用通配符"*"来表示允许来自任何域的请求。 此外,还有其他一些相关的标头字段,例如"Access-Control-Allow-Methods"用于指定允许的HTTP方法,"Access-Control-Allow-Headers"用于指定允许的请求头,以及"Access-Control-Allow-Credentials"用于指示是否允许发送身份验证凭据。 在客户端发起跨域请求时,浏览器会首先发送一个预检请求(OPTIONS请求),以获取服务器是否支持跨域请求。服务器收到预检请求后,会返回相应的响应头以及状态码,如果满足要求,则浏览器会发送实际的请求。 需要注意的是,CORS仅适用于浏览器发起的请求,对于直接通过HTTP工具发送的请求,不会受到CORS的限制。此外,CORS仅在符合同策略的情况下才会生效,即协议、域名和端口号必须完全相同。 希望这能解答你关于CORS跨域资源共享的问题!如果还有其他问题,请随时提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

乐享技术

每一个打赏,都是对我最大的鼓励

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

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

打赏作者

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

抵扣说明:

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

余额充值