当前位置: 代码网 > 服务器>服务器>Nginx > Nginx跨域访问配置方式(Web反向代理跨域访问配置)

Nginx跨域访问配置方式(Web反向代理跨域访问配置)

2024年07月03日 Nginx 我要评论
nginx跨域访问配置(web反向代理跨域访问配置)出于安全的原因,浏览器限制从脚本内发起跨域的http请求,除非响应报文中包含了允许浏览器解析报文的cors响应头也就是说,响应报文的头中要有以下几个

nginx跨域访问配置(web反向代理跨域访问配置)

出于安全的原因,浏览器限制从脚本内发起跨域的http请求,除非响应报文中包含了允许浏览器解析报文的cors响应头

也就是说,响应报文的头中要有以下几个响应头

nginx要使用add_header添加这几个响应头

1.前后端分离的工程

一般情况下是使用ajax访问后端接口

ajax的请求头为x-requested-with

因此服务端要允许x-requested-with的请求头

add_header 'access-control-allow-headers' 'x-requested-with';

2.服务端要配置哪些域

是可以跨域访问到本服务器资源的

add_header 'access-control-allow-origin' '*';

注意:

  • 如果使用了
add_header 'access-control-allow-credentials' 'true'
  • 那么不能使用通配符
add_header 'access-control-allow-origin' 'www.baidu.com';
add_header 'access-control-allow-credentials' 'true';

3.服务器端要指定http请求的方法

add_header 'access-control-allow-methods' 'get,post,options'

案例

add_header 'access-control-allow-origin' '*';
add_header 'access-control-allow-headers' 'x-requested-with';
add_header 'access-control-allow-methods' 'get,post,options'
# 由于跨域请求,浏览器会先发送一个options的预检请求,我们可以缓存第一次的预检请求的失效时间
if ($request_method = 'options') {
	add_header 'access-control-max-age' 2592000;
	add_header 'content-type' 'text/plain; charset=utf-8';
	add_header 'content-length' 0;
	return 204;
}

http请求头详解

对于跨域的配置,不是只有nginx可以配置,在spring中也提供了跨域访问的配置

详见corsfiltercorsconfigurationurlbasedcorsconfigurationsource

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com