热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Nginx反向代办跨域基础设置与罕见误区

近来公司前后端星散,前端自力供应页面和静态效劳很天然的就想到了用nginx去做静态效劳器。同时因为跨域了,就想应用nginx的反向代办去处置惩罚一下跨域,但是在解决题目的同时,发明

近来公司前后端星散,前端自力供应页面和静态效劳很天然的就想到了用nginx去做静态效劳器。同时因为跨域了,就想应用nginx的反向代办去处置惩罚一下跨域,但是在解决题目的同时,发明网上有些计划的确是存在一些题目,在这里总结一下基础设置,也聊一下罕见的设置题目。

Nginx接口效劳反向代办基础设置

server {
listen 8443; # 监听的端口号
server_name a.test.com; # 效劳器称号
client_max_body_size 100m; # 定义读取客户端要求头的超时时刻
ssl on;
ssl_certificate test.pem;
ssl_certificate_key test.key;
ssl_session_timeout 5m;
ssl_protocols SSLv3 TLSv1.2;
ssl_ciphers ECDHE-RSA-AES256-SHA384:AES256-SHA256:RC4:HIGH:!MD5:!aNULL:!eNULL:!NULL:!DH:!EDH:!AESGCM;
ssl_prefer_server_ciphers on;
location / {
root /test-static-app; # 静态资本目次
index index.html index.htm;
try_files $uri $uri/ /index.html; # 动态剖析目次,合营vue的history形式
}
}

基础设置完成了页面及静态效劳器的基础功能,并能够完成运用vue的history形式时的路由剖析。进一步的,为了完成向接口效劳器的一致转发,我们需要和后端开发人员划定接口名的前缀,比方一切接口的相对途径都以api开首,此时我们能够增加以下设置(和上一个location平级),

...
location /api {
proxy_pass https://b.test.com; # 设置代办效劳器的协媾和地点
proxy_COOKIE_domain b.test.com a.test.com; # 修正COOKIE,针对request和response相互写入COOKIE
}
...

个中重要依靠proxy_pass,完成将a.test.com下的/api/x接口转发到了b.test.com下面,这个历程大抵以下
《Nginx反向代办跨域基础设置与罕见误区》

COOKIE的交互重要就是proxy_COOKIE_domain,加上下面这段

proxy_COOKIE_domain b.test.com a.test.com;

这个完成了,a.test.com和b.test.com域名之间COOKIE的通报与回写。这里的明白有点误区,请移步到细致诠释Nginx反向代办明白误区之proxy_COOKIE_domain

假如用node来模仿一下的话,大抵以下

module.exports = (router) => {
router.get('/api/index/getCmsInfo', async function (ctx, next) {
// 接口转发
let result = await superagent.post('https://b.test.com/api/card/home').set(browserMsg)
// 猎取返回的set-COOKIE,并设置header
let setCOOKIE = result.headers['set-COOKIE']
if (setCOOKIE) {
ctx.response.header['set-COOKIE'] = setCOOKIE
}
// 返回
ctx.response.body={
success: true,
result: result.body
}
})
}

综上nginx反向代办的实质实在就是接口效劳的转发与header的处置惩罚,细致想一想也就轻易明白了。

罕见误区

1、无用的ACA-Header ?
网上许多的nginx跨域设置内里都加了跨域header设置相干的内容,比方

add_header 'Access-Control-Allow-Origin' '*';
add_header 'Access-Control-Allow-Credentials' "true";
add_header Access-Control-Allow-Headers X-Requested-With;

想一想上面的道理,列位看官以为这个还有效么?ACA(Access-Control-Allow-)系列的header自身是为了cors中做协商跨域而设置的,在这里配这个纯属脱裤子放屁节外生枝。
2、proxy_pass 域名带不带‘斜杠/’ ?
一样的,在网上看到了有的网友在设置proxy_pass的时刻,会在背面加一个斜杠,以下,然后说报错啦,找不到接口啦~咋整啊~

...
location /api {
#proxy_pass https://b.test.com;
proxy_pass https://b.test.com/;
}
...

看到这个我们来想一想哈,proxy_pass的作用是抓发,加了斜杠意味着一切的/api要求都邑转发到根目次下,也就是说 /api 会被 / 替换,这个时刻接口途径就变了,少了一层/api。而不加斜杠的时刻呢?这代表着转发到b.test.com 的域名下,/api的途径不会丧失。
针对这类状况,假如后端接口一致有了划定前缀,比方/api,那你这里就不要设置斜杠了。另一种状况,后端接口shit一样,没有一致前缀,这边又要辨别,那就在前端一切接口都加一个一致前缀,比方/api,然后经由过程加斜杠来替换掉好了~

以上就是本次的全部内容了~本日的《新闻联播》播送完了,感谢收看,再会~再会~


推荐阅读
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
  • 本文探讨了高质量C/C++编程的最佳实践,并详细分析了常见的内存错误及其解决方案。通过深入理解内存管理和故障排除技巧,开发者可以编写更健壮的程序。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 通过Web界面管理Linux日志的解决方案
    本指南介绍了一种利用rsyslog、MariaDB和LogAnalyzer搭建集中式日志管理平台的方法,使用户可以通过Web界面查看和分析Linux系统的日志记录。此方案不仅适用于服务器环境,还提供了详细的步骤来确保系统的稳定性和安全性。 ... [详细]
  • 采用IKE方式建立IPsec安全隧道
    一、【组网和实验环境】按如上的接口ip先作配置,再作ipsec的相关配置,配置文本见文章最后本文实验采用的交换机是H3C模拟器,下载地址如 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文介绍如何通过 JavaScript 实现一个基于鼠标坐标的 Tooltip 弹出层,详细解释了如何获取窗口和文档的尺寸及滚动位置,并优化了代码结构。 ... [详细]
  • 本文介绍了一种在 MySQL 客户端执行 NOW() 函数时出现时间偏差的问题,并详细描述了如何通过配置文件调整时区设置来解决该问题。演示场景中,假设当前北京时间为2023年2月17日19:31:37,而查询结果显示的时间比实际时间晚8小时。 ... [详细]
  • 本文详细介绍了如何通过RPM包在Linux系统(如CentOS)上安装MySQL 5.6。涵盖了检查现有安装、下载和安装RPM包、配置MySQL以及设置远程访问和开机自启动等步骤。 ... [详细]
  • Kubernetes 持久化存储与数据卷详解
    本文深入探讨 Kubernetes 中持久化存储的使用场景、PV/PVC/StorageClass 的基本操作及其实现原理,旨在帮助读者理解如何高效管理容器化应用的数据持久化需求。 ... [详细]
  • 探讨在 JavaScript 中使用不同方向的 for 循环来实现跟随鼠标的 div 动画时,为什么会出现不同的视觉效果。 ... [详细]
  • ZooKeeper集群脑裂问题及其解决方案
    本文深入探讨了ZooKeeper集群中可能出现的脑裂问题,分析其成因,并提供了多种有效的解决方案,确保集群在高可用性环境下的稳定运行。 ... [详细]
author-avatar
勇敢的刺鸟宝贝4164053383
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有