小知识:nginx 配置跨域失效修复的方法示例

nginx 配置跨域不生效 如下配置

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
server {
listen  80;
server_name localhost;
# 接口转发
location /api/ {
# 允许请求地址跨域 * 做为通配符
add_header Access-Control-Allow-Origin *;
# 设置请求方法跨域
add_header Access-Control-Allow-Methods GET, POST, OPTIONS, PUT, DELETE;
# 设置是否允许 cookie 传输
add_header Access-Control-Allow-Credentials true;
# 设置请求头 这里为什么不设置通配符 * 因为不支持
add_header Access-Control-Allow-Headers Authorization,Content-Type,Accept,Origin,User-Agent,DNT,Cache-Control,X-Mx-ReqToken,X-Data-Type,X-Requested-With,X-Data-Type,X-Auth-Token;
# 设置反向代理
proxy_pass 127.0.0.1:8081/;
}
}

网上的 nginx 跨域配置主要是以上版本,然而很多都是抄一抄,并没有真的去实践,故写了下文章提醒下有需要的人,不要盲目抄,学会分析。

nginx 修改如下配置后生效

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
server {
listen  80;
server_name localhost;
# 接口转发
location /api/ {
# 允许请求地址跨域 * 做为通配符
add_header Access-Control-Allow-Origin *;
# 设置请求方法跨域
add_header Access-Control-Allow-Methods GET, POST, OPTIONS, PUT, DELETE;
# 设置是否允许 cookie 传输
add_header Access-Control-Allow-Credentials true;
# 设置请求头 这里为什么不设置通配符 * 因为不支持
add_header Access-Control-Allow-Headers Authorization,Content-Type,Accept,Origin,User-Agent,DNT,Cache-Control,X-Mx-ReqToken,X-Data-Type,X-Requested-With,X-Data-Type,X-Auth-Token;
# 设置 options 请求处理
if ( $request_method = OPTIONS ) {
return 200;
}
# 设置反向代理
proxy_pass 127.0.0.1:8081/;
}
}

两者代码区别 主要就是下面这行代码

?
1
2
3
if ( $request_method = OPTIONS ) {
return 200;
}

因为 post 请求 浏览器会发送一个 options 的预检请求,主要将本次的请求头 发送给服务端,若服务端允许,再发送真正的post请求,所以 f12 看到,经常 post 会发送两次请求。因为后端 java 代码没有对 options 请求做出处理,导致 options 接口请求的时候,报 403 forbidden , 这里 nginx 对 options 的请求直接返回 200,不用到达接口层,直接允许 post 响应头,即可使得上述失效配置能够生效

附赠 一个小知识点

proxy_pass 127.0.0.1:8081/;

针对反向代理里面这个/ 加不加的问题;

访问 http://localhost/api/user/login;

加/ 则 实际访问的是 127.0.0.1:8081/user/login; 不加 / 则实际访问的是 127.0.0.1:8081/api/user/login;

加了斜杠意味着所有的 /api 请求都会转发到根目录下,也就是说 /api 会被 / 替代,这个时候接口路径就变了,少了一层 /api 。而不加斜杠的时候呢?这代表着转发到127.0.0.1:8081的域名下, /api 的路径不会丢失

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://segmentfault.com/a/1190000020725137

声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。
建站知识

小知识:详解Linux下随机生成密码的命令总结

2023-4-3 4:08:34

建站知识

小知识:Linux进程间通信--使用信号

2023-4-3 4:16:50

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索