Windows中使用Nginx解决前后端分离部署中的跨域问题
off999 2025-01-04 22:24 27 浏览 0 评论
说明
现在的Java Web项目好多都使用前后端分离的开发部署方式,这样的好处有很多,比如:可以实现真正的前后端解耦,可以减少后端服务器的并发/负载压力,方便实现多端应用(网页端、移动端共用一个后台服务)、增加代码的维护性&易读性。一般我们会采用Nginx来部署前端代码,使用Tomcat来部署后台服务。最近在Windows系统中使用Nginx部署前端代码时调用后台服务时出现了跨域的报错,通过对Nginx的一些代理配置可以解决这个问题,下面给大家分享一下在Nginx中部署前端代码并解决跨域问题的方法步骤。
解决跨域问题的思路:出现跨域问题的原因在于静态资源的访问地址是Nginx服务器的地址,比如http://ip1:port1,然后我们在静态页面中通过ajax请求后台服务获取数据,后台服务的地址是http://ip2:port2,这两个地址的ip端口不同,就导致了跨域问题的出现,那我们就需要访问一个和前端页面具有相同地址的后台服务才会避免跨越问题,可以设置一个代理,比如我们把后台服务访问地址换成http://ip1:port1/api/,然后通过一定的配置将http://ip1:port1/api/地址收到的请求转发到真正的后台服务地址http://ip2:port2,这样就可以避免跨域问题的出现。
在html目录下面放静态资源
把我们要部署的静态资源文件夹放到Nginx的html目录下面,例如testpage文件夹下面有一个index.html页面,直接把testpage文件夹放到Nginx的目录下面。
配置反向代理
打开Nginx conf目录下面的nginx.conf文件,在第一个server里面添加一个location对前端发送的服务调用请求地址进行过滤,配置如下:
location /api/ {
rewrite ^/api/(.*)$ /$1 break; #所有对后端的请求加一个api前缀方便区分,真正访问的时候移除这个前缀
# API Server
proxy_pass http://127.0.0.1:8092; #将真正的请求代理到真实的服务器地址,ajax的url为/api/user/1的请求将会访问http://127.0.0.1:8092/user/1
}经过上面的配置以后,我们的前端资源访问地址和ajax请求的后台服务地址就可以保持一致,从而避免了跨域问题的出现。
启动Nginx
首先在cmd命令窗口中切换到nginx所在的目录,然后输入命令:
start nginx.exe停止Nginx
在cmd命令窗口中输入:
nginx.exe -s stop注意事项
1、有时候使用命令nginx.exe -s stop停不掉Nginx,可以使用命令taskkill /f /t /im nginx.exe强制关闭Nginx进程。
相关推荐
- outlook注册官网(outlook注册官网入口)
-
1.访问outlook.com,点击“创建新帐户”。2.点击“创建新Outlook帐户”,输入你的用户名、密码、国家/地区、生日、性别,然后点击“创建帐户”,即可完成注册。登陆邮箱被告知此账号不存...
-
- win7哪个系统最好(win7哪家系统好用)
-
Win7系统中,最好用的版本是Windows7Professional。它提供了广泛的功能和优秀的性能,适用于个人和商业用户。Windows7Professional具有稳定的操作系统,易于使用且具备高度的兼容性。它提供了许多高级功...
-
2025-12-09 08:03 off999
- win10整理磁盘碎片的步骤(win10整理磁盘碎片的步骤包括)
-
1、首先电脑桌面上打开(我的电脑),然后选择需要碎片整理的磁盘,如右键E盘,再单击属性。 2、在磁盘属性页面,点工具栏,在工具栏下面看到磁片整...
- win11有一键ghost(win11有一键还原系统吗)
-
应该是系统设置上的问题。使用右键点击计算机选择属性-高级系统设置-点击启动和故障恢复栏的设置-最上面那个默认启动操作系统是不是设置在系统上,如果是设置在ghost上那就更改过来。如果这上面设置正确那么...
- cad2015序列号(序列号cad2016)
-
AutoCAD2020安装序列号:666-69696969、667-98989898、400-45454545、066-66666666AutoCAD2020产品密钥:001L1AutoCAD201...
-
- 应用程序发生异常(应用程序发生异常unKnown software)
-
打开或关闭某程序时出现内存不能为的提示,说明这个程序与系统中其他的程序有冲突的地方,建议在操作某程序的时候关闭一切程序包括杀毒软件,和暂时关闭杀毒软件的监控功能和带有的监控功能的其他程序。如果还经常出现错误的提示,将这个程序卸载,再重新下载...
-
2025-12-09 05:03 off999
- 免费海外ip地址(免费海外ip地址查询)
-
56.23.52.41美国北卡罗来纳(美国邮政局)62.164.192.6462.164.192.95英国KidderminsterCollege69.240.0.069.243.255.25...
- 移动硬盘不显示怎么修复(移动硬盘不显示怎么修复呢)
-
1、移动硬盘插入电脑,选择计算机,选择左侧“此电脑”,点击右击。2、选择“管理”点击,进入计算机管理;选择磁盘“磁盘管理”。3、如没有看到移动硬盘,可以选择右边的更多操作,重新扫描磁盘。4、如依然没有...
- 技术员联盟系统(技术员联盟官网)
-
区别一:纯净版就是指安装完了以后是一个windows的初始环境,没有安装其他任何第三方软件。装机版就是装好以后还会继续安装一些制作者添加的第三方软件,比如说下载工具啊,聊天工具啊什么的。安装版指的是用...
- win10系统如何还原系统(win10还原系统方法)
-
要想恢复到Win10原版系统,可以通过两种方式。一种是使用Win10系统恢复工具,该工具可以在Win10设置中找到,然后选择恢复选项,并按照步骤完成恢复操作即可。另一种方式是直接从Microsoft官...
- 老毛桃xp u盘启动(老毛桃xp u盘启动)
-
老毛桃安装纯净版XP的方法需要用到的工具:winxp纯净版系统iso镜像+启动U盘1、进入老毛桃,选第一个PE后找到我们事先准备好的纯净版系统iso镜像,右键点击加载虚拟磁盘(也可以利用虚拟光驱来加载...
- 无线wifi密码破解工具
-
WiFi万能密码WiFi万能密码可免费连接WiFi,极速发现无线WiFi信号,一键即可连接上网,同时还能检测WiFi的信号轻度及安全度,让你想怎么玩就怎么玩,不必在担心流量的问题。这款软件操作简单,一...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
使用 python-fire 快速构建 CLI_如何搭建python项目架构
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
