欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
session與cookie

一、術(shù)語(yǔ)session
在我的經(jīng)驗里,session這個(gè)詞被濫用的程度大概僅次于transaction,更加有趣的是transaction與session在某些語(yǔ)境下的含義是相同的。

session,中文經(jīng)常翻譯為會(huì )話(huà),其本來(lái)的含義是指有始有終的一系列動(dòng)作/消息,比如打電話(huà)時(shí)從拿起電話(huà)撥號到掛斷電話(huà)這中間的一系列過(guò)程可以稱(chēng)之為一個(gè)session。有時(shí)候我們可以看到這樣的話(huà)“在一個(gè)瀏覽器會(huì )話(huà)期間,...”,這里的會(huì )話(huà)一詞用的就是其本義,是指從一個(gè)瀏覽器窗口打開(kāi)到關(guān)閉這個(gè)期間①。最混亂的是“用戶(hù)(客戶(hù)端)在一次會(huì )話(huà)期間”這樣一句話(huà),它可能指用戶(hù)的一系列動(dòng)作(一般情況下是同某個(gè)具體目的相關(guān)的一系列動(dòng)作,比如從登錄到選購商品到結賬登出這樣一個(gè)網(wǎng)上購物的過(guò)程,有時(shí)候也被稱(chēng)為一個(gè)transaction),然而有時(shí)候也可能僅僅是指一次連接,也有可能是指含義①,其中的差別只能靠上下文來(lái)推斷②。

然而當session一詞與網(wǎng)絡(luò )協(xié)議相關(guān)聯(lián)時(shí),它又往往隱含了“面向連接”和/或“保持狀態(tài)”這樣兩個(gè)含義,“面向連接”指的是在通信雙方在通信之前要先建立一個(gè)通信的渠道,比如打電話(huà),直到對方接了電話(huà)通信才能開(kāi)始,與此相對的是寫(xiě)信,在你把信發(fā)出去的時(shí)候你并不能確認對方的地址是否正確,通信渠道不一定能建立,但對發(fā)信人來(lái)說(shuō),通信已經(jīng)開(kāi)始了。“保持狀態(tài)”則是指通信的一方能夠把一系列的消息關(guān)聯(lián)起來(lái),使得消息之間可以互相依賴(lài),比如一個(gè)服務(wù)員能夠認出再次光臨的老顧客并且記得上次這個(gè)顧客還欠店里一塊錢(qián)。這一類(lèi)的例子有“一個(gè)TCP session”或者“一個(gè)POP3 session”③。

而到了web服務(wù)器蓬勃發(fā)展的時(shí)代,session在web開(kāi)發(fā)語(yǔ)境下的語(yǔ)義又有了新的擴展,它的含義是指一類(lèi)用來(lái)在客戶(hù)端與服務(wù)器之間保持狀態(tài)的解決方案④。有時(shí)候session也用來(lái)指這種解決方案的存儲結構,如“把xxx保存在session里”⑤。由于各種用于web開(kāi)發(fā)的語(yǔ)言在一定程度上都提供了對這種解決方案的支持,所以在某種特定語(yǔ)言的語(yǔ)境下,session也被用來(lái)指代該語(yǔ)言的解決方案,比如經(jīng)常把Java里提供的javax.servlet.http.HttpSession簡(jiǎn)稱(chēng)為session⑥。

鑒于這種混亂已不可改變,本文中session一詞的運用也會(huì )根據上下文有不同的含義,請大家注意分辨。
在本文中,使用中文“瀏覽器會(huì )話(huà)期間”來(lái)表達含義①,使用“session機制”來(lái)表達含義④,使用“session”表達含義⑤,使用具體的“HttpSession”來(lái)表達含義⑥

二、HTTP協(xié)議與狀態(tài)保持
HTTP協(xié)議本身是無(wú)狀態(tài)的,這與HTTP協(xié)議本來(lái)的目的是相符的,客戶(hù)端只需要簡(jiǎn)單的向服務(wù)器請求下載某些文件,無(wú)論是客戶(hù)端還是服務(wù)器都沒(méi)有必要紀錄彼此過(guò)去的行為,每一次請求之間都是獨立的,好比一個(gè)顧客和一個(gè)自動(dòng)售貨機或者一個(gè)普通的(非會(huì )員制)大賣(mài)場(chǎng)之間的關(guān)系一樣。

然而聰明(或者貪心?)的人們很快發(fā)現如果能夠提供一些按需生成的動(dòng)態(tài)信息會(huì )使web變得更加有用,就像給有線(xiàn)電視加上點(diǎn)播功能一樣。這種需求一方面迫使HTML逐步添加了表單、腳本、DOM等客戶(hù)端行為,另一方面在服務(wù)器端則出現了CGI規范以響應客戶(hù)端的動(dòng)態(tài)請求,作為傳輸載體的HTTP協(xié)議也添加了文件上載、cookie這些特性。其中cookie的作用就是為了解決HTTP協(xié)議無(wú)狀態(tài)的缺陷所作出的努力。至于后來(lái)出現的session機制則是又一種在客戶(hù)端與服務(wù)器之間保持狀態(tài)的解決方案。

讓我們用幾個(gè)例子來(lái)描述一下cookie和session機制之間的區別與聯(lián)系。筆者曾經(jīng)常去的一家咖啡店有喝5杯咖啡免費贈一杯咖啡的優(yōu)惠,然而一次性消費5杯咖啡的機會(huì )微乎其微,這時(shí)就需要某種方式來(lái)紀錄某位顧客的消費數量。想象一下其實(shí)也無(wú)外乎下面的幾種方案:
1、該店的店員很厲害,能記住每位顧客的消費數量,只要顧客一走進(jìn)咖啡店,店員就知道該怎么對待了。這種做法就是協(xié)議本身支持狀態(tài)。
2、發(fā)給顧客一張卡片,上面記錄著(zhù)消費的數量,一般還有個(gè)有效期限。每次消費時(shí),如果顧客出示這張卡片,則此次消費就會(huì )與以前或以后的消費相聯(lián)系起來(lái)。這種做法就是在客戶(hù)端保持狀態(tài)。
3、發(fā)給顧客一張會(huì )員卡,除了卡號之外什么信息也不紀錄,每次消費時(shí),如果顧客出示該卡片,則店員在店里的紀錄本上找到這個(gè)卡號對應的紀錄添加一些消費信息。這種做法就是在服務(wù)器端保持狀態(tài)。

由于HTTP協(xié)議是無(wú)狀態(tài)的,而出于種種考慮也不希望使之成為有狀態(tài)的,因此,后面兩種方案就成為現實(shí)的選擇。具體來(lái)說(shuō)cookie機制采用的是在客戶(hù)端保持狀態(tài)的方案,而session機制采用的是在服務(wù)器端保持狀態(tài)的方案。同時(shí)我們也看到,由于采用服務(wù)器端保持狀態(tài)的方案在客戶(hù)端也需要保存一個(gè)標識,所以session機制可能需要借助于cookie機制來(lái)達到保存標識的目的,但實(shí)際上它還有其他選擇。

三、理解cookie機制
cookie機制的基本原理就如上面的例子一樣簡(jiǎn)單,但是還有幾個(gè)問(wèn)題需要解決:“會(huì )員卡”如何分發(fā);“會(huì )員卡”的內容;以及客戶(hù)如何使用“會(huì )員卡”。

正統的cookie分發(fā)是通過(guò)擴展HTTP協(xié)議來(lái)實(shí)現的,服務(wù)器通過(guò)在HTTP的響應頭中加上一行特殊的指示以提示瀏覽器按照指示生成相應的cookie。然而純粹的客戶(hù)端腳本如JavaScript或者VBScript也可以生成cookie。

而cookie的使用是由瀏覽器按照一定的原則在后臺自動(dòng)發(fā)送給服務(wù)器的。瀏覽器檢查所有存儲的cookie,如果某個(gè)cookie所聲明的作用范圍大于等于將要請求的資源所在的位置,則把該cookie附在請求資源的HTTP請求頭上發(fā)送給服務(wù)器。意思是麥當勞的會(huì )員卡只能在麥當勞的店里出示,如果某家分店還發(fā)行了自己的會(huì )員卡,那么進(jìn)這家店的時(shí)候除了要出示麥當勞的會(huì )員卡,還要出示這家店的會(huì )員卡。

cookie的內容主要包括:名字,值,過(guò)期時(shí)間,路徑和域。
其中域可以指定某一個(gè)域比如.google.com,相當于總店招牌,比如寶潔公司,也可以指定一個(gè)域下的具體某臺機器比如www.google.com或者froogle.google.com,可以用飄柔來(lái)做比。
路徑就是跟在域名后面的URL路徑,比如/或者/foo等等,可以用某飄柔專(zhuān)柜做比。
路徑與域合在一起就構成了cookie的作用范圍。
如果不設置過(guò)期時(shí)間,則表示這個(gè)cookie的生命期為瀏覽器會(huì )話(huà)期間,只要關(guān)閉瀏覽器窗口,cookie就消失了。這種生命期為瀏覽器會(huì )話(huà)期的cookie被稱(chēng)為會(huì )話(huà)cookie。會(huì )話(huà)cookie一般不存儲在硬盤(pán)上而是保存在內存里,當然這種行為并不是規范規定的。如果設置了過(guò)期時(shí)間,瀏覽器就會(huì )把cookie保存到硬盤(pán)上,關(guān)閉后再次打開(kāi)瀏覽器,這些cookie仍然有效直到超過(guò)設定的過(guò)期時(shí)間。

存儲在硬盤(pán)上的cookie可以在不同的瀏覽器進(jìn)程間共享,比如兩個(gè)IE窗口。而對于保存在內存里的cookie,不同的瀏覽器有不同的處理方式。對于IE,在一個(gè)打開(kāi)的窗口上按Ctrl-N(或者從文件菜單)打開(kāi)的窗口可以與原窗口共享,而使用其他方式新開(kāi)的IE進(jìn)程則不能共享已經(jīng)打開(kāi)的窗口的內存cookie;對于Mozilla Firefox0.8,所有的進(jìn)程和標簽頁(yè)都可以共享同樣的cookie。一般來(lái)說(shuō)是用javascript的window.open打開(kāi)的窗口會(huì )與原窗口共享內存cookie。瀏覽器對于會(huì )話(huà)cookie的這種只認cookie不認人的處理方式經(jīng)常給采用session機制的web應用程序開(kāi)發(fā)者造成很大的困擾。

下面就是一個(gè)goolge設置cookie的響應頭的例子
HTTP/1.1 302 Found
Location: http://www.google.com/intl/zh-CN/
Set-Cookie: PREF=ID=0565f77e132de138:NW=1:TM=1098082649:LM=1098082649:S=KaeaCFPo49RiA_d8; expires=Sun, 17-Jan-2038 19:14:07 GMT; path=/; domain=.google.com
Content-Type: text/html


這是使用HTTPLook這個(gè)HTTP Sniffer軟件來(lái)俘獲的HTTP通訊紀錄的一部分


瀏覽器在再次訪(fǎng)問(wèn)goolge的資源時(shí)自動(dòng)向外發(fā)送cookie


使用Firefox可以很容易的觀(guān)察現有的cookie的值
使用HTTPLook配合Firefox可以很容易的理解cookie的工作原理。


IE也可以設置在接受cookie前詢(xún)問(wèn)


這是一個(gè)詢(xún)問(wèn)接受cookie的對話(huà)框。

四、理解session機制
session機制是一種服務(wù)器端的機制,服務(wù)器使用一種類(lèi)似于散列表的結構(也可能就是使用散列表)來(lái)保存信息。

當程序需要為某個(gè)客戶(hù)端的請求創(chuàng )建一個(gè)session的時(shí)候,服務(wù)器首先檢查這個(gè)客戶(hù)端的請求里是否已包含了一個(gè)session標識 - 稱(chēng)為session id,如果已包含一個(gè)session id則說(shuō)明以前已經(jīng)為此客戶(hù)端創(chuàng )建過(guò)session,服務(wù)器就按照session id把這個(gè)session檢索出來(lái)使用(如果檢索不到,可能會(huì )新建一個(gè)),如果客戶(hù)端請求不包含session id,則為此客戶(hù)端創(chuàng )建一個(gè)session并且生成一個(gè)與此session相關(guān)聯(lián)的session id,session id的值應該是一個(gè)既不會(huì )重復,又不容易被找到規律以仿造的字符串,這個(gè)session id將被在本次響應中返回給客戶(hù)端保存。

保存這個(gè)session id的方式可以采用cookie,這樣在交互過(guò)程中瀏覽器可以自動(dòng)的按照規則把這個(gè)標識發(fā)揮給服務(wù)器。一般這個(gè)cookie的名字都是類(lèi)似于SEEESIONID,而。比如weblogic對于web應用程序生成的cookie,JSESSIONID=ByOK3vjFD75aPnrF7C2HmdnV6QZcEbzWoWiBYEnLerjQ99zWpBng!-145788764,它的名字就是JSESSIONID。

由于cookie可以被人為的禁止,必須有其他機制以便在cookie被禁止時(shí)仍然能夠把session id傳遞回服務(wù)器。經(jīng)常被使用的一種技術(shù)叫做URL重寫(xiě),就是把session id直接附加在URL路徑的后面,附加方式也有兩種,一種是作為URL路徑的附加信息,表現形式為http://...../xxx;jsessionid=ByOK3vjFD75aPnrF7C2HmdnV6QZcEbzWoWiBYEnLerjQ99zWpBng!-145788764
另一種是作為查詢(xún)字符串附加在URL后面,表現形式為http://...../xxx?jsessionid=ByOK3vjFD75aPnrF7C2HmdnV6QZcEbzWoWiBYEnLerjQ99zWpBng!-145788764
這兩種方式對于用戶(hù)來(lái)說(shuō)是沒(méi)有區別的,只是服務(wù)器在解析的時(shí)候處理的方式不同,采用第一種方式也有利于把session id的信息和正常程序參數區分開(kāi)來(lái)。
為了在整個(gè)交互過(guò)程中始終保持狀態(tài),就必須在每個(gè)客戶(hù)端可能請求的路徑后面都包含這個(gè)session id。

另一種技術(shù)叫做表單隱藏字段。就是服務(wù)器會(huì )自動(dòng)修改表單,添加一個(gè)隱藏字段,以便在表單提交時(shí)能夠把session id傳遞回服務(wù)器。比如下面的表單
<form name="testform" action="/xxx">
<input type="text">
</form>
在被傳遞給客戶(hù)端之前將被改寫(xiě)成
<form name="testform" action="/xxx">
<input type="hidden" name="jsessionid" value="ByOK3vjFD75aPnrF7C2HmdnV6QZcEbzWoWiBYEnLerjQ99zWpBng!-145788764">
<input type="text">
</form>
這種技術(shù)現在已較少應用,筆者接觸過(guò)的很古老的iPlanet6(SunONE應用服務(wù)器的前身)就使用了這種技術(shù)。
實(shí)際上這種技術(shù)可以簡(jiǎn)單的用對action應用URL重寫(xiě)來(lái)代替。

在談?wù)搒ession機制的時(shí)候,常常聽(tīng)到這樣一種誤解“只要關(guān)閉瀏覽器,session就消失了”。其實(shí)可以想象一下會(huì )員卡的例子,除非顧客主動(dòng)對店家提出銷(xiāo)卡,否則店家絕對不會(huì )輕易刪除顧客的資料。對session來(lái)說(shuō)也是一樣的,除非程序通知服務(wù)器刪除一個(gè)session,否則服務(wù)器會(huì )一直保留,程序一般都是在用戶(hù)做log off的時(shí)候發(fā)個(gè)指令去刪除session。然而瀏覽器從來(lái)不會(huì )主動(dòng)在關(guān)閉之前通知服務(wù)器它將要關(guān)閉,因此服務(wù)器根本不會(huì )有機會(huì )知道瀏覽器已經(jīng)關(guān)閉,之所以會(huì )有這種錯覺(jué),是大部分session機制都使用會(huì )話(huà)cookie來(lái)保存session id,而關(guān)閉瀏覽器后這個(gè)session id就消失了,再次連接服務(wù)器時(shí)也就無(wú)法找到原來(lái)的session。如果服務(wù)器設置的cookie被保存到硬盤(pán)上,或者使用某種手段改寫(xiě)瀏覽器發(fā)出的HTTP請求頭,把原來(lái)的session id發(fā)送給服務(wù)器,則再次打開(kāi)瀏覽器仍然能夠找到原來(lái)的session。

恰恰是由于關(guān)閉瀏覽器不會(huì )導致session被刪除,迫使服務(wù)器為seesion設置了一個(gè)失效時(shí)間,當距離客戶(hù)端上一次使用session的時(shí)間超過(guò)這個(gè)失效時(shí)間時(shí),服務(wù)器就可以認為客戶(hù)端已經(jīng)停止了活動(dòng),才會(huì )把session刪除以節省存儲空間。

五、理解javax.servlet.http.HttpSession
HttpSession是Java平臺對session機制的實(shí)現規范,因為它僅僅是個(gè)接口,具體到每個(gè)web應用服務(wù)器的提供商,除了對規范支持之外,仍然會(huì )有一些規范里沒(méi)有規定的細微差異。這里我們以BEA的Weblogic Server8.1作為例子來(lái)演示。

首先,Weblogic Server提供了一系列的參數來(lái)控制它的HttpSession的實(shí)現,包括使用cookie的開(kāi)關(guān)選項,使用URL重寫(xiě)的開(kāi)關(guān)選項,session持久化的設置,session失效時(shí)間的設置,以及針對cookie的各種設置,比如設置cookie的名字、路徑、域,cookie的生存時(shí)間等。

一般情況下,session都是存儲在內存里,當服務(wù)器進(jìn)程被停止或者重啟的時(shí)候,內存里的session也會(huì )被清空,如果設置了session的持久化特性,服務(wù)器就會(huì )把session保存到硬盤(pán)上,當服務(wù)器進(jìn)程重新啟動(dòng)或這些信息將能夠被再次使用,Weblogic Server支持的持久性方式包括文件、數據庫、客戶(hù)端cookie保存和復制。

復制嚴格說(shuō)來(lái)不算持久化保存,因為session實(shí)際上還是保存在內存里,不過(guò)同樣的信息被復制到各個(gè)cluster內的服務(wù)器進(jìn)程中,這樣即使某個(gè)服務(wù)器進(jìn)程停止工作也仍然可以從其他進(jìn)程中取得session。

cookie生存時(shí)間的設置則會(huì )影響瀏覽器生成的cookie是否是一個(gè)會(huì )話(huà)cookie。默認是使用會(huì )話(huà)cookie。有興趣的可以用它來(lái)試驗我們在第四節里提到的那個(gè)誤解。

cookie的路徑對于web應用程序來(lái)說(shuō)是一個(gè)非常重要的選項,Weblogic Server對這個(gè)選項的默認處理方式使得它與其他服務(wù)器有明顯的區別。后面我們會(huì )專(zhuān)題討論。

關(guān)于session的設置參考[5] http://e-docs.bea.com/wls/docs70/webapp/weblogic_xml.html#1036869

六、HttpSession常見(jiàn)問(wèn)題
(在本小節中session的含義為⑤和⑥的混合)


1、session在何時(shí)被創(chuàng )建
一個(gè)常見(jiàn)的誤解是以為session在有客戶(hù)端訪(fǎng)問(wèn)時(shí)就被創(chuàng )建,然而事實(shí)是直到某server端程序調用HttpServletRequest.getSession(true)這樣的語(yǔ)句時(shí)才被創(chuàng )建,注意如果JSP沒(méi)有顯示的使用 <%@page session="false"%> 關(guān)閉session,則JSP文件在編譯成Servlet時(shí)將會(huì )自動(dòng)加上這樣一條語(yǔ)句HttpSession session = HttpServletRequest.getSession(true);這也是JSP中隱含的session對象的來(lái)歷。

由于session會(huì )消耗內存資源,因此,如果不打算使用session,應該在所有的JSP中關(guān)閉它。

2、session何時(shí)被刪除
綜合前面的討論,session在下列情況下被刪除a.程序調用HttpSession.invalidate();或b.距離上一次收到客戶(hù)端發(fā)送的session id時(shí)間間隔超過(guò)了session的超時(shí)設置;或c.服務(wù)器進(jìn)程被停止(非持久session)

3、如何做到在瀏覽器關(guān)閉時(shí)刪除session
嚴格的講,做不到這一點(diǎn)??梢宰鲆稽c(diǎn)努力的辦法是在所有的客戶(hù)端頁(yè)面里使用javascript代碼window.oncolose來(lái)監視瀏覽器的關(guān)閉動(dòng)作,然后向服務(wù)器發(fā)送一個(gè)請求來(lái)刪除session。但是對于瀏覽器崩潰或者強行殺死進(jìn)程這些非常規手段仍然無(wú)能為力。

4、有個(gè)HttpSessionListener是怎么回事
你可以創(chuàng )建這樣的listener去監控session的創(chuàng )建和銷(xiāo)毀事件,使得在發(fā)生這樣的事件時(shí)你可以做一些相應的工作。注意是session的創(chuàng )建和銷(xiāo)毀動(dòng)作觸發(fā)listener,而不是相反。類(lèi)似的與HttpSession有關(guān)的listener還有HttpSessionBindingListener,HttpSessionActivationListener和HttpSessionAttributeListener。

5、存放在session中的對象必須是可序列化的嗎
不是必需的。要求對象可序列化只是為了session能夠在集群中被復制或者能夠持久保存或者在必要時(shí)server能夠暫時(shí)把session交換出內存。在Weblogic Server的session中放置一個(gè)不可序列化的對象在控制臺上會(huì )收到一個(gè)警告。我所用過(guò)的某個(gè)iPlanet版本如果session中有不可序列化的對象,在session銷(xiāo)毀時(shí)會(huì )有一個(gè)Exception,很奇怪。

6、如何才能正確的應付客戶(hù)端禁止cookie的可能性
對所有的URL使用URL重寫(xiě),包括超鏈接,form的action,和重定向的URL,具體做法參見(jiàn)[6]
http://e-docs.bea.com/wls/docs70/webapp/sessions.html#100770

7、開(kāi)兩個(gè)瀏覽器窗口訪(fǎng)問(wèn)應用程序會(huì )使用同一個(gè)session還是不同的session
參見(jiàn)第三小節對cookie的討論,對session來(lái)說(shuō)是只認id不認人,因此不同的瀏覽器,不同的窗口打開(kāi)方式以及不同的cookie存儲方式都會(huì )對這個(gè)問(wèn)題的答案有影響。

8、如何防止用戶(hù)打開(kāi)兩個(gè)瀏覽器窗口操作導致的session混亂
這個(gè)問(wèn)題與防止表單多次提交是類(lèi)似的,可以通過(guò)設置客戶(hù)端的令牌來(lái)解決。就是在服務(wù)器每次生成一個(gè)不同的id返回給客戶(hù)端,同時(shí)保存在session里,客戶(hù)端提交表單時(shí)必須把這個(gè)id也返回服務(wù)器,程序首先比較返回的id與保存在session里的值是否一致,如果不一致則說(shuō)明本次操作已經(jīng)被提交過(guò)了??梢詤⒖础禞2EE核心模式》關(guān)于表示層模式的部分。需要注意的是對于使用javascript window.open打開(kāi)的窗口,一般不設置這個(gè)id,或者使用單獨的id,以防主窗口無(wú)法操作,建議不要再window.open打開(kāi)的窗口里做修改操作,這樣就可以不用設置。

9、為什么在Weblogic Server中改變session的值后要重新調用一次session.setValue
做這個(gè)動(dòng)作主要是為了在集群環(huán)境中提示W(wǎng)eblogic Server session中的值發(fā)生了改變,需要向其他服務(wù)器進(jìn)程復制新的session值。

10、為什么session不見(jiàn)了
排除session正常失效的因素之外,服務(wù)器本身的可能性應該是微乎其微的,雖然筆者在iPlanet6SP1加若干補丁的Solaris版本上倒也遇到過(guò);瀏覽器插件的可能性次之,筆者也遇到過(guò)3721插件造成的問(wèn)題;理論上防火墻或者代理服務(wù)器在cookie處理上也有可能會(huì )出現問(wèn)題。
出現這一問(wèn)題的大部分原因都是程序的錯誤,最常見(jiàn)的就是在一個(gè)應用程序中去訪(fǎng)問(wèn)另外一個(gè)應用程序。我們在下一節討論這個(gè)問(wèn)題。

七、跨應用程序的session共享

常常有這樣的情況,一個(gè)大項目被分割成若干小項目開(kāi)發(fā),為了能夠互不干擾,要求每個(gè)小項目作為一個(gè)單獨的web應用程序開(kāi)發(fā),可是到了最后突然發(fā)現某幾個(gè)小項目之間需要共享一些信息,或者想使用session來(lái)實(shí)現SSO(single sign on),在session中保存login的用戶(hù)信息,最自然的要求是應用程序間能夠訪(fǎng)問(wèn)彼此的session。

然而按照Servlet規范,session的作用范圍應該僅僅限于當前應用程序下,不同的應用程序之間是不能夠互相訪(fǎng)問(wèn)對方的session的。各個(gè)應用服務(wù)器從實(shí)際效果上都遵守了這一規范,但是實(shí)現的細節卻可能各有不同,因此解決跨應用程序session共享的方法也各不相同。

首先來(lái)看一下Tomcat是如何實(shí)現web應用程序之間session的隔離的,從Tomcat設置的cookie路徑來(lái)看,它對不同的應用程序設置的cookie路徑是不同的,這樣不同的應用程序所用的session id是不同的,因此即使在同一個(gè)瀏覽器窗口里訪(fǎng)問(wèn)不同的應用程序,發(fā)送給服務(wù)器的session id也可以是不同的。

根據這個(gè)特性,我們可以推測Tomcat中session的內存結構大致如下。

筆者以前用過(guò)的iPlanet也采用的是同樣的方式,估計SunONE與iPlanet之間不會(huì )有太大的差別。對于這種方式的服務(wù)器,解決的思路很簡(jiǎn)單,實(shí)際實(shí)行起來(lái)也不難。要么讓所有的應用程序共享一個(gè)session id,要么讓?xiě)贸绦蚰軌颢@得其他應用程序的session id。

iPlanet中有一種很簡(jiǎn)單的方法來(lái)實(shí)現共享一個(gè)session id,那就是把各個(gè)應用程序的cookie路徑都設為/(實(shí)際上應該是/NASApp,對于應用程序來(lái)講它的作用相當于根)。
<session-info>
<path>/NASApp</path>
</session-info>

需要注意的是,操作共享的session應該遵循一些編程約定,比如在session attribute名字的前面加上應用程序的前綴,使得setAttribute("name", "neo")變成setAttribute("app1.name", "neo"),以防止命名空間沖突,導致互相覆蓋。


在Tomcat中則沒(méi)有這么方便的選擇。在Tomcat版本3上,我們還可以有一些手段來(lái)共享session。對于版本4以上的Tomcat,目前筆者尚未發(fā)現簡(jiǎn)單的辦法。只能借助于第三方的力量,比如使用文件、數據庫、JMS或者客戶(hù)端cookie,URL參數或者隱藏字段等手段。

我們再看一下Weblogic Server是如何處理session的。

從截屏畫(huà)面上可以看到Weblogic Server對所有的應用程序設置的cookie的路徑都是/,這是不是意味著(zhù)在Weblogic Server中默認的就可以共享session了呢?然而一個(gè)小實(shí)驗即可證明即使不同的應用程序使用的是同一個(gè)session,各個(gè)應用程序仍然只能訪(fǎng)問(wèn)自己所設置的那些屬性。這說(shuō)明Weblogic Server中的session的內存結構可能如下

對于這樣一種結構,在session機制本身上來(lái)解決session共享的問(wèn)題應該是不可能的了。除了借助于第三方的力量,比如使用文件、數據庫、JMS或者客戶(hù)端cookie,URL參數或者隱藏字段等手段,還有一種較為方便的做法,就是把一個(gè)應用程序的session放到ServletContext中,這樣另外一個(gè)應用程序就可以從ServletContext中取得前一個(gè)應用程序的引用。示例代碼如下,

應用程序A
context.setAttribute("appA", session);

應用程序B
contextA = context.getContext("/appA");
HttpSession sessionA = (HttpSession)contextA.getAttribute("appA");

值得注意的是這種用法不可移植,因為根據ServletContext的JavaDoc,應用服務(wù)器可以處于安全的原因對于context.getContext("/appA");返回空值,以上做法在Weblogic Server 8.1中通過(guò)。

那么Weblogic Server為什么要把所有的應用程序的cookie路徑都設為/呢?原來(lái)是為了SSO,凡是共享這個(gè)session的應用程序都可以共享認證的信息。一個(gè)簡(jiǎn)單的實(shí)驗就可以證明這一點(diǎn),修改首先登錄的那個(gè)應用程序的描述符weblogic.xml,把cookie路徑修改為/appA訪(fǎng)問(wèn)另外一個(gè)應用程序會(huì )重新要求登錄,即使是反過(guò)來(lái),先訪(fǎng)問(wèn)cookie路徑為/的應用程序,再訪(fǎng)問(wèn)修改過(guò)路徑的這個(gè),雖然不再提示登錄,但是登錄的用戶(hù)信息也會(huì )丟失。注意做這個(gè)實(shí)驗時(shí)認證方式應該使用FORM,因為瀏覽器和web服務(wù)器對basic認證方式有其他的處理方式,第二次請求的認證不是通過(guò)session來(lái)實(shí)現的。具體請參看[7] secion 14.8 Authorization,你可以修改所附的示例程序來(lái)做這些試驗。

八、總結
session機制本身并不復雜,然而其實(shí)現和配置上的靈活性卻使得具體情況復雜多變。這也要求我們不能把僅僅某一次的經(jīng)驗或者某一個(gè)瀏覽器,服務(wù)器的經(jīng)驗當作普遍適用的經(jīng)驗,而是始終需要具體情況具體分析。

本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
Session那些事(一)
深入理解Servlet/JSP之“Cookie和Session原理”
response.encodeURL的用法 - 神雕大俠 - JavaEye技術(shù)網(wǎng)站
HttpSession服務(wù)器端會(huì )話(huà)技術(shù)
Java基礎-關(guān)于session的詳細解釋 (2)
關(guān)閉瀏覽器后再次訪(fǎng)問(wèn)session 保證是同一個(gè)sessionid
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久