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;

}

posted @ 2017-12-27 16:47  阿狸哥哥  阅读(24498)  评论(0编辑  收藏  举报