為什麼會有jsessionid,這個東東有什麼用呢?,jsessionid這個東東

來源:互聯網
上載者:User

為什麼會有jsessionid,這個東東有什麼用呢?,jsessionid這個東東

1.是不是只要一開啟一個頁面就會產生一個jsessionid?  2.在不關閉瀏覽器的情況下,什麼時候jsessionid會改變?我登陸後,登陸然後退出,jsessionid會有什麼變化?  3.session和jsessionid有什麼關係?  謝謝!

所謂session可以這樣理解:當與服務端進行會話時,比如說登陸成功後,服務端會為使用者開壁一塊記憶體區間,用以存放使用者這次會話的一些內容,比如說使用者名稱之類的。那麼就需要一個東西來標誌這個記憶體區間是你的而不是別人的,這個東西就是session id(jsessionid只是tomcat中對session id的叫法,在其它容器裡面,不一定就是叫jsessionid了。),而這個記憶體區間你可以理解為session。  然後,伺服器會將這個session id發回給你的瀏覽器,放入你的瀏覽器的cookies中(這個cookies是記憶體cookies,跟一般的不一樣,它會隨著瀏覽器的關閉而消失)。  之後,只有你瀏覽器沒有關閉,你每向伺服器發請求,伺服器就會從你發送過來的cookies中拿出這個session id,然後根據這個session id到相應的記憶體中取你之前存放的資料。  但是,如果你退出登陸了,伺服器會清掉屬於你的記憶體地區,所以你再登的話,會產生一個新的session了。

jsession是什麼:jsessionid是session的標識。這就好比每個人都有身份證一樣。

 

jsessionid解釋的解釋如下:

這是一個保險措施  因為Session預設是需要Cookie支援的,但有些客戶瀏覽器是關閉Cookie的【而jsessionid是儲存在Cookie中的,如果禁用Cookie的話,也就是說伺服器那邊得不到jsessionid,這樣也就沒法根據jsessionid獲得對應的session了,獲得不了session就得不到session中儲存的資料了。】  這個時候就需要在URL中指定伺服器上的session標識,也就是類似於“jsessionid=5F4771183629C9834F8382E23BE13C4C” 這種格式。  用一個方法(忘了方法的名字)處理URL串就可以得到這個東西,這個方法會判斷你的瀏覽器是否開啟了Cookie,如果他認為應該加他就會加上去。

1.是不是只要一開啟一個頁面就會產生一個jsessionid?  答:顯然不是的。session是有一定範圍的,而且是有時間限制的。

2.在不關閉瀏覽器的情況下,什麼時候jsessionid會改變?我登陸後,登陸然後退出,jsessionid會有什麼變化?  答:jsessionid是伺服器那邊產生的,因為cookie是伺服器那邊送到用戶端的資訊。不管能不能修改jsessionid,都不應該修改,如果你修改了,這就失去了jessionid的自身意義了,你修改的話,你讓伺服器那邊如何找到對應的session?找不到的話,你存放在那個session中的資料不是取不到了嗎?  登陸然後退出,我認為會重建一個jsessionid。因為退出的話,application範圍的資料都會丟失,更何況這個比它範圍還小的session?既然session都消失了,這個jsessionid有什麼用?

3.jsessionid是session的標識。這就好比每個人都有身份證一樣。

cookie和session機制區別與聯絡     具體來說cookie機制採用的是在用戶端保持狀態的方案,而session機制採用的是在伺服器端保持狀態的方案。同時我們也看到,由於採用伺服器端保持狀態的方案在用戶端也需要儲存一個標識,所以session機制可能需要藉助於cookie機制來達到儲存標識的目的,但實際上它還有其他選擇。

    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,不同的瀏覽器有不同的處理方式      session機制。session機制是一種伺服器端的機制,伺服器使用一種類似於散列表的結構(也可能就是使用散列表)來儲存資訊。      當程式需要為某個用戶端的請求建立一個session時,伺服器首先檢查這個用戶端的請求裡是否已包含了一個session標識(稱為session id),如果已包含則說明以前已經為此用戶端建立過session,伺服器就按照session id把這個session檢索出來使用(檢索不到,會建立一個),如果用戶端請求不包含session id,則為此用戶端建立一個session並且產生一個與此session相關聯的session id,session id的值應該是一個既不會重複,又不容易被找到規律以仿造的字串,這個session id將被在本次響應中返回給用戶端儲存。      儲存這個session id的方式可以採用cookie,這樣在互動過程中瀏覽器可以自動的按照規則把這個標識發揮給伺服器。一般這個cookie的名字都是類似於SEEESIONID。但cookie可以被人為的禁止,則必須有其他機制以便在cookie被禁止時仍然能夠把session id傳遞迴伺服器。      經常被使用的一種技術叫做URL重寫,就是把session id直接附加在URL路徑的後面。還有一種技術叫做表單隱藏欄位。就是伺服器會自動修改表單,添加一個隱藏欄位,以便在表單提交時能夠把session id傳遞迴伺服器。

擷取【】 springmvc mybatis(oracle 和 mysql) HTML5 全新高大尚後台架構 bootstrap

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.