nginx代理跳转到内网ip上去了

nginx反向代理了一个tomcat,大概就是这样:

{
server_name www.xxx.com;

.....
proxy_pass http://127.0.0.1:8080;
.....
}

通过域名访问该项目可以正常进入首页,但是输入用户名和密码登录后点击登录,这时会发现浏览器地址变成了http://127.0.0.1:8080/xxx/yyy, 更奇葩的是点击浏览器的返回键再次输入用户名密码进行登录又能正常跳转,百思不得其解,后来我发现凡是在项目中使用了重定向的接口,必然会出现这种情况,于是肯定是项目的重定向有什么问题。

我用的chrome浏览器,F12,network里面勾选Preserve log就可以保证重定向的请求不会被清掉,然后输入用户名和密码点击登录,发现其实登录成功了,状态码是302,显然是服务器叫浏览器重定向,但是Response header 中Location属性是http://127.0.0.1:8080/xxx/yyy, 也就是说服务器返的Location属性有问题,最终找到tomcat 的conf/server.xml 的Connector标签中有
proxyName 和 proxyPort 两个属性,专门用来处理tomcat被代理的这种情况,proxyName="www.xxx.com" proxyPort="80" ,加上这两个属性后重启tomcat,问题解决
Nginx 反向代理是一种常见的网络架构设计,主要用于负载均衡、URL重定向和内部服务间的通信。在某些场景下,如果想要让内网的服务可以通过公网访问(即内网穿透),你可以按照以下步骤配置 Nginx: 1. **环境准备**: - 确保你已经在服务器上安装了 Nginx。 - 需要有一个公网IP地址,或者已经设置了端口映射(如NAT、DMZ等)。 2. **配置 Nginx**: 在 Nginx 的配置文件(一般为 `nginx.conf` 或 `sites-available/your-site.conf`)中,新建或编辑一个虚拟主机块(server block)。设置如下示例配置: ```nginx server { listen 80; # 公网监听的端口,根据实际情况更改 server_name yourdomain.com; # 替换为你自己的域名 location / { proxy_pass http://your_internal_ip:internal_port; # 内网服务的 IP 和端口 proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } # 如果需要 SSL/TLS,添加以下内容 # ssl_certificate_path /path/to/certificate; # ssl_certificate_key_path /path/to/key; # 错误页面处理 error_page 502 /502.html; location = /502.html { root /usr/share/nginx/html; # 默认路径,也可以自定义 } } ``` 3. **重启 Nginx**: 修改完配置后,执行 `sudo service nginx reload` 或者 `sudo systemctl restart nginx` 命令使新配置生效。 4. **测试**: 尝试从公网访问 `http://yourdomain.com`,Nginx 应该会转发请求到内网指定的服务器并返回响应。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值