• nginx 反向代理session失效问题


    背景

    经了解,他对同一个项目使用tomcat部署了两个环境,一个在开发服务器上,一个在他本机,两个环境代码配置完全相同。两边通过同一个nginx进行反向代理,nginx配置大致如下,

    location /health/ {
        proxy_pass  http://192.168.40.159:8081/health/;  #无问题的配置
     }
    
    location /health-dev/ {
        proxy_pass  http://192.168.40.202:8080/health/;  #有问题的配置
    }
    

    一个反向代理到开发环境,一个反向代理到本机服务。

    定位

    既然代码配置完全相同,那么问题很大可能就出现在nginx的反向代理上。

    因为两边location路径不同(即浏览器路径不同),但是反向代理的服务端路径却相同,结合session的基本原理,如下图,

    httpsession

    1. 当浏览器第一次打开页面时,服务端会为这次会话创建一个session,并将session id通过response的header传递给浏览器,header一般为 Set-Cookie: JSESSIONID=xxxxx; Path=xxxx
    2. 浏览器接收到响应后,如果header Set-Cookie 中path的值与浏览器地址路径匹配,则将该header值存于浏览器的Cookie中
    3. 浏览器在下次请求服务器时,将Cookie中的JSESSIONID值通过request的header上报给服务端,header一般为 Cookie: JSESSIONID=xxxx;
    4. 服务端可通过该JSESSIONID来定位到对应的session

    nginx反向代理按这种方式配置时

    location /health-dev/ {
        proxy_pass  http://192.168.40.202:8080/health/;
    }
    

    浏览器访问 http://www.domian.com/health-dev 时,服务端返回的 Set-Cookie 的 Path 值为 /health(因为中间有反向代理,服务端并不知道代理前的路径是啥,是按最终请求服务端的路径设置),如图

    nginx-proxy-cookie-1

    因为浏览器访问地址的路径 /health-dev 与 Set-Cookie 的 Path /health 不匹配,所以浏览器并不会将其值存入Cookie中,如图

    nginx-proxy-cookie-2

    因此在下次请求服务器时,浏览器无法设置request Cookie header的 JSESSIONID 值,服务器无法定位到对应的session,因此会将其当做第一次请求,创建一个新的session,如此反复,因此就算你登录认证通过了,但服务器返回的登录凭证(JSESSIONID)浏览器不会保存,并在下次请求时携带,导致服务器认为你是一个新的请求,当然就会又跳到登录页面了。

    解决

    nginx有一个命令 proxy_cookie_path(参考: proxy_cookie_path)可将服务器返回的 Set-Cookie 中的path进行修改,格式为 proxy_cookie_path 原路径 目标路径,我们在配置中添加 proxy_cookie_path 如下。

    location /health-dev/ {
        proxy_pass  http://192.168.40.202:8080/health/;
        proxy_cookie_path  /health /health-dev;
    }
    

    重启nginx,问题解决。

    转发自:https://www.cnblogs.com/spec-dog/p/13292111.html

  • 相关阅读:
    根据对象中某个元素进行排序
    Bootstrap 弹出框(Popover)插件
    echarts+bmap 去掉地图左下角的logo
    get提交参数中存在空格
    long类型的转换为正常时间格式遇到的问题
    jQuery validate使用过程中遇到的问题
    问题 G: 最长公共子串问题
    1567. 乘积为正数的最长子数组长度(dp)
    C. Parsa's Humongous Tree(树形dp)
    1558. 得到目标数组的最少函数调用次数
  • 原文地址:https://www.cnblogs.com/sweetsunnyflower/p/13386197.html
Copyright © 2020-2023  润新知