spring session無法實(shí)現(xiàn)共享(多web應(yīng)用)

問題背景

  • 最近在做一個(gè)session共享的業(yè)務(wù)唁盏,接手的項(xiàng)目中是通過tomcat-redis-session-manager-master這個(gè)jar包實(shí)現(xiàn)的session共享,該jar包依賴于tomcat容器检眯。而現(xiàn)在的項(xiàng)目需求是不依賴于特定容器厘擂,對該項(xiàng)目的session共享進(jìn)行相關(guān)修改。通過查找相關(guān)資料轰传,發(fā)現(xiàn)spring session符合要求。對于spring session的相關(guān)介紹瘪撇,這里就不做闡述了获茬,看官可自行查找。

問題描述

  • 接手的項(xiàng)目中通過多個(gè)web應(yīng)用的war包進(jìn)行項(xiàng)目協(xié)作倔既,然而在使用spring session進(jìn)行session共享的時(shí)候恕曲,發(fā)現(xiàn)各web都是單獨(dú)的sessionId,并且存儲在Redis中。也就是說渤涌,各web應(yīng)用之間并沒有實(shí)現(xiàn)session共享佩谣,從而也就無法實(shí)現(xiàn)單點(diǎn)登錄功能。

問題解決

  • 通過查看spring session相關(guān)源碼發(fā)現(xiàn)实蓬,在包路徑 org.springframework.session.web.http下有一個(gè)DefaultCookieSerializer類茸俭,該類有一個(gè)方法getCookiePath(HttpServletRequest request),下面為源碼相關(guān)內(nèi)容安皱,其中的syso為我調(diào)試的時(shí)候自己打印的log。
private String getCookiePath(HttpServletRequest request) {
        if (this.cookiePath == null) {
            System.out.println("cookiePath-->" + request.getContextPath());
            return request.getContextPath() + "/";
        }
        return this.cookiePath;
    }
  • 通過上面的打印log,我發(fā)現(xiàn)該方法返回的cookiePath是web項(xiàng)目的子域路徑,也就是說叛拷,如果一個(gè)項(xiàng)目為localhost:8080/abc卷员,另一個(gè)項(xiàng)目為localhost:8080/def(該端口也可以不為8080),那么spring session就會認(rèn)為兩個(gè)項(xiàng)目的cookiePath分別為/abc和/def,從而也就認(rèn)定這兩個(gè)項(xiàng)目不為同一個(gè)cookiePath居砖,最終也就導(dǎo)致問題的出現(xiàn)虹脯,無法實(shí)現(xiàn)session共享。
  • 解決該問題奏候,我們可以通過修改源碼返回的cookiePath循集,使得其認(rèn)為的cookiePath路徑一致,修改后的源碼為:
private String getCookiePath(HttpServletRequest request) {
//      if (this.cookiePath == null) {
//          System.out.println("cookiePath-->" + request.getContextPath());
//          return request.getContextPath() + "/";
//      }
//      return this.cookiePath;
        return "/";
    }

此方式為所有返回的cookiePath都為“/”蔗草,也就使得各web應(yīng)用的cookiePath一致了暇榴。當(dāng)然厚棵,具體的修改還要根據(jù)實(shí)際項(xiàng)目進(jìn)行,但是最終解決的思路是一樣的蔼紧,各web應(yīng)用返回的cookiePath一致

  • 對于如何修改源碼
    1.第一種比較直接暴力的就是修改spring seesion源碼婆硬,并重新打成jar包
    2.第二種就是讓程序復(fù)用DefaultCookieSerializer類,在每個(gè)web項(xiàng)目中分別新建一個(gè)類DefaultCookieSerializer類奸例,先假如該類所在的包為com.test彬犯,復(fù)制源碼中DefaultCookieSerializer類的內(nèi)容放入你自己新建的DefaultCookieSerializer類中,由于篇幅問題查吊,我就不把DefaultCookieSerializer類的內(nèi)容放出來了谐区,只要按上面所說的將getCookiePath(HttpServletRequest request)返回值修改就可以了。新建類中在這個(gè)地方會出現(xiàn)報(bào)錯(cuò):
    private boolean isServlet3()
    {
//        ServletRequest.getMethod("startAsync", new Class[0]);
        return true;
//        NoSuchMethodException nosuchmethodexception;
//        nosuchmethodexception;
//        return false;
    }

為了方便演示逻卖,我就直接將相關(guān)報(bào)錯(cuò)注釋掉了宋列,看官可自行斟酌。
3.第三種就是修改各個(gè)web應(yīng)用的域名评也,還是那句話炼杖,最終解決的思路是一樣的,讓spring session對各web應(yīng)用返回的cookiePath一致
4.新建好DefaultCookieSerializer類之后盗迟,需要修改applicationContext.xml(我的項(xiàng)目是直接在該xml中進(jìn)行spring session相關(guān)配置坤邪,看官可根據(jù)自己項(xiàng)目在相應(yīng)的xml中對spring session進(jìn)行配置),在xml中添加以下內(nèi)容:

<bean id="defaultCookieSerializer" class="com.test.DefaultCookieSerializer" />
    <bean class="org.springframework.session.web.http.CookieHttpSessionStrategy">
        <property name="cookieSerializer" ref="defaultCookieSerializer" />
    </bean>
    <bean class="org.springframework.session.config.annotation.web.http.SpringHttpSessionConfiguration">
        <property name="cookieSerializer" ref="defaultCookieSerializer" />
    </bean>

5.至此罚缕,對于spring session多web應(yīng)用無法實(shí)現(xiàn)session共享的問題解決了艇纺。

總結(jié)

  • 看官如果遇到這種問題,可以嘗試使用本文所闡述的方法進(jìn)行相關(guān)配置邮弹。如果不行的話黔衡,請繼續(xù)填坑,加油!
  • 本文使用的spring session包版本為spring-session-1.2.1-RELEASE.jar腌乡,可能不同的版本包內(nèi)容上會有些不同员帮,還是那句話,最終解決的思路是一樣的导饲,讓spring session對各web應(yīng)用返回的cookiePath一致捞高,重要的事終于說了3遍了
  • 小生退下了,看官您受累渣锦!
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末硝岗,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子袋毙,更是在濱河造成了極大的恐慌型檀,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件听盖,死亡現(xiàn)場離奇詭異胀溺,居然都是意外死亡裂七,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進(jìn)店門仓坞,熙熙樓的掌柜王于貴愁眉苦臉地迎上來背零,“玉大人,你說我怎么就攤上這事无埃♂闫浚” “怎么了?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵嫉称,是天一觀的道長侦镇。 經(jīng)常有香客問我,道長织阅,這世上最難降的妖魔是什么壳繁? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮荔棉,結(jié)果婚禮上闹炉,老公的妹妹穿的比我還像新娘。我一直安慰自己江耀,他們只是感情好剩胁,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布诉植。 她就那樣靜靜地躺著祥国,像睡著了一般。 火紅的嫁衣襯著肌膚如雪晾腔。 梳的紋絲不亂的頭發(fā)上舌稀,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天,我揣著相機(jī)與錄音灼擂,去河邊找鬼壁查。 笑死,一個(gè)胖子當(dāng)著我的面吹牛剔应,可吹牛的內(nèi)容都是我干的睡腿。 我是一名探鬼主播,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼峻贮,長吁一口氣:“原來是場噩夢啊……” “哼席怪!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起纤控,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤挂捻,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后船万,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體刻撒,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡骨田,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了声怔。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片态贤。...
    茶點(diǎn)故事閱讀 38,137評論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖捧搞,靈堂內(nèi)的尸體忽然破棺而出抵卫,到底是詐尸還是另有隱情,我是刑警寧澤胎撇,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布介粘,位于F島的核電站,受9級特大地震影響晚树,放射性物質(zhì)發(fā)生泄漏姻采。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一爵憎、第九天 我趴在偏房一處隱蔽的房頂上張望慨亲。 院中可真熱鬧,春花似錦宝鼓、人聲如沸刑棵。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蛉签。三九已至,卻和暖如春沥寥,著一層夾襖步出監(jiān)牢的瞬間碍舍,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工邑雅, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留片橡,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓淮野,卻偏偏與公主長得像捧书,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子骤星,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評論 2 345

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理经瓷,服務(wù)發(fā)現(xiàn),斷路器妈踊,智...
    卡卡羅2017閱讀 134,601評論 18 139
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,748評論 6 342
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,522評論 25 707
  • 關(guān)于股票期貨市場! 站在以十年為單位的考量下歪泳,長期看漲萝勤,中期偏空,短期就是震蕩找時(shí)機(jī)爆發(fā)呐伞!完敌卓!就是這么個(gè)走法! 先...
    縱情嬉戲天地間閱讀 122評論 0 0
  • 過年了伶氢,陽光也已經(jīng)出來了趟径。丘陵地區(qū)怎么能夠趕上一連十幾天的下雪呢?二十號的雪早已經(jīng)停了癣防,這一天是暖和的蜗巧。 李鵬一大...
    楊扶搖閱讀 189評論 0 2