Session與Cookie的區別

cookie和session機制區別與聯繫瀏覽器

具 體來講cookie機制採用的是在客戶端保持狀態的方案,而session機制採用的是在服務器端保持狀態的方案。同時咱們也看到,因爲採用服務器端保持 狀態的方案在客戶端也須要保存一個標識,因此session機制可能須要藉助於cookie機制來達到保存標識的目的,但實際上它還有其餘選擇。

1.cookie 機制。正統的cookie分發是經過擴展HTTP協議來實現的,服務器經過在HTTP的響應頭中加上一行特殊的指示以提示瀏覽器按照指示生成相應的 cookie。然而純粹的客戶端腳本如JavaScript或者VBScript也能夠生成cookie。而cookie的使用是由瀏覽器按照必定的原則 在後臺自動發送給服務器的。瀏覽器檢查全部存儲的cookie,若是某個cookie所聲明的做用範圍大於等於將要請求的資源所在的位置,則把該 cookie附在請求資源的HTTP請求頭上發送給服務器。

cookie的內容主要包括:名字,值,過時時間,路徑和域。路徑與域一 起構成cookie的做用範圍。若不設置過時時間,則表示這個cookie的生命期爲瀏覽器會話期間,關閉瀏覽器窗口,cookie就消失。這種生命期爲 瀏覽器會話期的cookie被稱爲會話cookie。會話cookie通常不存儲在硬盤上而是保存在內存裏,固然這種行爲並非規範規定的。若設置了過時 時間,瀏覽器就會把cookie保存到硬盤上,關閉後再次打開瀏覽器,這些cookie仍然有效直到超過設定的過時時間。存儲在硬盤上的cookie能夠 在不一樣的瀏覽器進程間共享,好比兩個IE窗口。而對於保存在內存裏的cookie,不一樣的瀏覽器有不一樣的處理方式
2.session機制。session機制是一種服務器端的機制,服務器使用一種相似於散列表的結構(也可能就是使用散列表)來保存信息。

當 程序須要爲某個客戶端的請求建立一個session時,服務器首先檢查這個客戶端的請求裏是否已包含了一個session標識(稱爲 sessionid),若是已包含則說明之前已經爲此客戶端建立過session,服務器就按照sessionid把這個session檢索出來使用(檢 索不到,會新建一個),若是客戶端請求不包含sessionid,則爲此客戶端建立一個session而且生成一個與此session相關聯的 session id,sessionid的值應該是一個既不會重複,又不容易被找到規律以仿造的字符串,這個session id將被在本次響應中返回給客戶端保存。

保存這個sessionid的方式能夠採用cookie,這樣在交互過程當中瀏覽器能夠自動的按照 規則把這個標識發揮給服務器。通常這個cookie的名字都是相似於SEEESIONID。但cookie能夠被人爲的禁止,則必須有其餘機制以便在 cookie被禁止時仍然可以把sessionid傳遞迴服務器。

常常被使用的一種技術叫作URL重寫,就是把session id直接附加在URL路徑的後面。
服務器

response.encodeURL() 使 URL 包含 session ID,若是你須要使用重定向,可使用 response.encodeRedirectURL () 來對 URL 進行編碼。cookie

例:cookie沒有禁用,超連接爲<a href="hello.jsp"/>session

cookie禁用了,URL重寫爲,<a href="<%=response.encodeURL("hello.jsp")%>"/> jsp

  encodeURL () 及 encodeRedirectedURL () 方法首先判斷 cookie 是否被瀏覽器支持;若是支持,則參數 URL 被原樣返回,session ID 將經過 cookie來維持。編碼

還有一種技術叫作表單隱藏字段。就是服務器會自動修改表單,添加一個隱藏字段,以便在表單提交時可以把sessionid傳遞迴服務器。好比:
<form name="testform" action="/xxx">
<input type="hidden" name="jsessionid" 
value="ByOK3vjFD75aPnrF7C2HmdnV6QZcEbzWoWiBYEnLerjQ99zWpBng!-145788764">
<input type="text">
</form>

實際上這種技術能夠簡單的用對action應用URL重寫來代替。
spa

相關文章
相關標籤/搜索