session運行機制

session機制是一種服務器端的機制织中,服務器使用一種類似于散列表的結(jié)構(gòu)(也可能就是使用散列表)來保存信息。
當程序需要為某個客戶端的請求創(chuàng)建一個session的時候怯屉,服務器首先檢查這個客戶端的請求里是否已包含了一個session標識-稱為sessionid涩盾,如果已包含一個sessionid則說明以前已經(jīng)為此客戶端創(chuàng)建過session,服務器就按照sessionid把這個session檢索出來使用(如果檢索不到丧蘸,可能會新建一個),如果客戶端請求不包含sessionid遥皂,則為此客戶端創(chuàng)建一個session并且生成一個與此session相關聯(lián)的sessionid力喷,sessionid的值應該是一個既不會重復,又不容易被找到規(guī)律以仿造的字符串演训,這個sessionid將被在本次響應中返回給客戶端保存弟孟。
保存這個sessionid的方式可以采用cookie,這樣在交互過程中瀏覽器可以自動的按照規(guī)則把這個標識發(fā)揮給服務器样悟。一般這個cookie的名字都是類似于SEEESIONID拂募,而。比如weblogic對于web應用程序生成的cookie窟她,JSESSIONID=ByOK3vjFD75aPnrF7C2HmdnV6QZcEbzWoWiBYEnLerjQ99zWpBng!-145788764陈症,它的名字就是JSESSIONID。
由于cookie可以被人為的禁止震糖,必須有其他機制以便在cookie被禁止時仍然能夠把sessionid傳遞回服務器录肯。經(jīng)常被使用的一種技術叫做URL重寫,就是把sessionid直接附加在URL路徑的后面吊说,附加方式也有兩種论咏,一種是作為URL路徑的附加信息,表現(xiàn)形式為http://...../xxx;jsessionid=ByOK3vjFD75aPnrF7C2HmdnV6QZcEbzWoWiBYEnLerjQ99zWpBng!-145788764
另一種是作為查詢字符串附加在URL后面颁井,表現(xiàn)形式為http://...../xxx?jsessionid=ByOK3vjFD75aPnrF7C2HmdnV6QZcEbzWoWiBYEnLerjQ99zWpBng!-145788764
這兩種方式對于用戶來說是沒有區(qū)別的厅贪,只是服務器在解析的時候處理的方式不同,采用第一種方式也有利于把sessionid的信息和正常程序參數(shù)區(qū)分開來雅宾。
為了在整個交互過程中始終保持狀態(tài)养涮,就必須在每個客戶端可能請求的路徑后面都包含這個sessionid。
另一種技術叫做表單隱藏字段。就是服務器會自動修改表單单寂,添加一個隱藏字段贬芥,以便在表單提交時能夠把sessionid傳遞回服務器。比如下面的表單
<formname="testform"action="/xxx">
<inputtype="text">
</form>
在被傳遞給客戶端之前將被改寫成
<formname="testform"action="/xxx">
<inputtype="hidden"name="jsessionid"value="ByOK3vjFD75aPnrF7C2HmdnV6QZcEbzWoWiBYEnLerjQ99zWpBng!-145788764">
<inputtype="text">
</form>
這種技術現(xiàn)在已較少應用宣决,筆者接觸過的很古老的iPlanet6(SunONE應用服務器的前身)就使用了這種技術蘸劈。
實際上這種技術可以簡單的用對action應用URL重寫來代替。
在談論session機制的時候尊沸,常常聽到這樣一種誤解“只要關閉瀏覽器威沫,session就消失了”。其實可以想象一下會員卡的例子洼专,除非顧客主動對店家提出銷卡棒掠,否則店家絕對不會輕易刪除顧客的資料。對session來說也是一樣的屁商,除非程序通知服務器刪除一個session烟很,否則服務器會一直保留,程序一般都是在用戶做logoff的時候發(fā)個指令去刪除session蜡镶。然而瀏覽器從來不會主動在關閉之前通知服務器它將要關閉雾袱,因此服務器根本不會有機會知道瀏覽器已經(jīng)關閉,之所以會有這種錯覺官还,是大部分session機制都使用會話cookie來保存sessionid芹橡,而關閉瀏覽器后這個sessionid就消失了,再次連接服務器時也就無法找到原來的session望伦。如果服務器設置的cookie被保存到硬盤上林说,或者使用某種手段改寫瀏覽器發(fā)出的HTTP請求頭,把原來的sessionid發(fā)送給服務器屯伞,則再次打開瀏覽器仍然能夠找到原來的session腿箩。 [Page]
恰恰是由于關閉瀏覽器不會導致session被刪除,迫使服務器為seesion設置了一個失效時間劣摇,當距離客戶端上一次使用session的時間超過這個失效時間時珠移,服務器就可以認為客戶端已經(jīng)停止了活動,才會把session刪除以節(jié)省存儲空間饵撑。

?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市唆貌,隨后出現(xiàn)的幾起案子滑潘,更是在濱河造成了極大的恐慌,老刑警劉巖锨咙,帶你破解...
    沈念sama閱讀 222,000評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件语卤,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機粹舵,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評論 3 399
  • 文/潘曉璐 我一進店門钮孵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人眼滤,你說我怎么就攤上這事巴席。” “怎么了诅需?”我有些...
    開封第一講書人閱讀 168,561評論 0 360
  • 文/不壞的土叔 我叫張陵漾唉,是天一觀的道長。 經(jīng)常有香客問我堰塌,道長赵刑,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,782評論 1 298
  • 正文 為了忘掉前任场刑,我火速辦了婚禮般此,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘牵现。我一直安慰自己铐懊,他們只是感情好,可當我...
    茶點故事閱讀 68,798評論 6 397
  • 文/花漫 我一把揭開白布施籍。 她就那樣靜靜地躺著居扒,像睡著了一般。 火紅的嫁衣襯著肌膚如雪丑慎。 梳的紋絲不亂的頭發(fā)上喜喂,一...
    開封第一講書人閱讀 52,394評論 1 310
  • 那天,我揣著相機與錄音竿裂,去河邊找鬼玉吁。 笑死,一個胖子當著我的面吹牛腻异,可吹牛的內(nèi)容都是我干的进副。 我是一名探鬼主播,決...
    沈念sama閱讀 40,952評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼悔常,長吁一口氣:“原來是場噩夢啊……” “哼影斑!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起机打,我...
    開封第一講書人閱讀 39,852評論 0 276
  • 序言:老撾萬榮一對情侶失蹤矫户,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后残邀,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體皆辽,經(jīng)...
    沈念sama閱讀 46,409評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡柑蛇,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,483評論 3 341
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了驱闷。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片耻台。...
    茶點故事閱讀 40,615評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖空另,靈堂內(nèi)的尸體忽然破棺而出盆耽,到底是詐尸還是另有隱情,我是刑警寧澤痹换,帶...
    沈念sama閱讀 36,303評論 5 350
  • 正文 年R本政府宣布征字,位于F島的核電站,受9級特大地震影響娇豫,放射性物質(zhì)發(fā)生泄漏匙姜。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,979評論 3 334
  • 文/蒙蒙 一冯痢、第九天 我趴在偏房一處隱蔽的房頂上張望氮昧。 院中可真熱鬧,春花似錦浦楣、人聲如沸袖肥。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,470評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽椎组。三九已至,卻和暖如春历恐,著一層夾襖步出監(jiān)牢的瞬間寸癌,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,571評論 1 272
  • 我被黑心中介騙來泰國打工弱贼, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留蒸苇,地道東北人。 一個月前我還...
    沈念sama閱讀 49,041評論 3 377
  • 正文 我出身青樓吮旅,卻偏偏與公主長得像溪烤,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子庇勃,可洞房花燭夜當晚...
    茶點故事閱讀 45,630評論 2 359

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