zoukankan      html  css  js  c++  java
  • 相同域名下的cookie污染

    • 问题描述

       本地用同一个tomcat调试两个相同框架的不同项目,在同一个浏览器界面里切换时,A项目的登录会把B项目的登录给踢掉,翻反过来亦如此。通过查看浏览器cookie,发现两个项目的cookie完全一模一样,只是值不同而已。

    • 原因解析
        通过查询资料大致可以了解到,如果是首次登录,服务器会创建sessionId返回给浏览器,浏览器会将sessionId保存为JSessionId,下次发起访问的时候会把sessionId带上,服务器通过判断是否存在sessionId,如果不存在则跳转登录页,存在则进行业务操作。所以A项目登录之后B项目接着去登陆,服务器返回给B项目一个新的sessionId,浏览器获取到之后会覆盖掉A项目的,等到A发起下次请求的时候,把覆盖掉的sessionId发送给服务器,服务器检测不到该sessionId,会以为sessionId已经过期,所以重定向到登录页。
    • 解决方法
      方法一
        设置不同域名,可以设置两个项目的域名不同,也就是区分到不同服务器上。
        如:http://projectA.com:7777/
          http://projectB.com:8080/
      方法二
        设置不同的应用名称,不是通过根路径的方式访问(未验证过)
        如:http://ip1:7777/projectA
          http://ip1:8080/projectB
      方法三
        设置cookie的别名

        1、通过在contex中设置:

      <Context sessionCookieName="jss" >

        2、或者通过java虚拟机参数

      -Dorg.apache.catalina.SESSION_COOKIE_NAME=jss

        3、或者动过设置:

      System.setProperty("org.apache.catalina.SESSION_COOKIE_NAME", "jss");

       

       

  • 相关阅读:
    C++类内存分布
    职场人理财之指数基金篇
    职场之殇---有些事情千万不能做
    职场人为什么需要理财
    职场发展之跟对老板有多重要
    职场中怎么做好一个演讲
    多线程如何按指定顺序同步执行
    多线程抢票系统浅析
    Spring Boot进阶系列三
    Spring Boot进阶系列二
  • 原文地址:https://www.cnblogs.com/zhouyun-yx/p/10900198.html
Copyright © 2011-2022 走看看