nginx使用proxy_pass反向代理时cookie丢失问题解决方案

来源:互联网 发布:c语言a =b 编辑:程序博客网 时间:2024/04/23 21:50

今天在测试环境进行测试时发现有个会话页面无论如何都进不去了,经过调试发现,JSESSIONID的path和我访问应用的path不相同!即我访问的应用是/xxx/,而JSESSIONID的path是/yyy/,这就是问题的根源!于是我就修改应用的sessionCookiePath,说白了就是在项目根路径下的META-INF下新建一个context.xml文件,具体内容为:

<?xml version="1.0" encoding="UTF-8"?> 

<Context useHttpOnly="true"  sessionCookiePath="/xxx/" />

在测试环境一试,成功通过,即只要两个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;
    }
1 0
原创粉丝点击