Nginx反向代理丢失cookie的问题


今天在测试环境进行测试时发现有个页面无论如何都进不去了,经过调试发现,JSESSIONID的path和我访问应用的工程不相同!我访问的应用是/xxx/,而JSESSIONID的path是/yyy/,这就是问题的根源!

于是我就修改应用的sessionCookiePath,说白了就是在项目根路径下的META-INF下新建一个context.xml文件,具体内容为:

在测试环境成功通过,即只要两个path不一致,就会重现测试环境上的问题,怀着喜悦的心情上测试环境进行测试,结果居然还是不行,调试发现JSESSIONID的path还是原来的/yyy/,居然没有起作用!

后来经过思考,修改tomcat是不行的,而应该修改nginx,即通过nginx修改JSESSIONID的路径,实验成功!下面是一些具体知识:

1. 如果只是host、端口转换,则cookie不会丢失。

例如: location /project {

    proxy_pass http://127.0.0.1:8080/project;

  }

通过浏览器访问http://127.0.0.1/project时,浏览器的cookie内有jsessionid。再次访问时,浏览器会发送当前的cookie。

2. 如果路径也变化了,则需要设置cookie的路径转换,nginx.conf的配置如下

location /proxy_path {

proxy_pass http://127.0.0.1:8080/project;

}

通过浏览器访问http://127.0.0.1/proxy_path时,浏览器的cookie内没有jsessionid。再次访问时,后台当然无法获取到cookie了。

加上路径转换:proxy_cookie_path /project /proxy_path; 则可以将project的cookie输出到proxy_path上。

正确的配置是:

location /proxy_path {

proxy_pass http://127.0.0.1:8080/project;

proxy_cookie_path /project /proxy_path;

}


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM