nginx代理跳转到内网ip上去了
nginx反向代理了一个tomcat,大概就是这样:
{
server_namewww.xxx.com;
.....
proxy_passhttp://127.0.0.1:8080;
.....
}
通过域名访问该项目可以正常进入首页,但是输入用户名和密码登录后点击登录,这时会发现浏览器地址变成了http://127.0.0.1:8080/xxx/yyy,更奇葩的是点击浏览器的返回键再次输入用户名密码进行登录又能正常跳转,百思不得其解,后来我发现凡是在项目中使用了重定向的接口,必然会出现这种情况,于是肯定是项目的重定向有什么问题。
我用的chrome浏览器,F12,network里面勾选Preservelog就可以保证重定向的请求不会被清掉,然后输入用户名和密码点击登录,发现其实登录成功了,状态码是302,显然是服务器叫浏览器重定向,但是Responseheader中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反向代理来来解决这些问题。比如现在我们用mirror.example.com镜像www.baidu.com,以下是详细操作。