當瀏覽器關閉時,Session就被銷毀了?

2021-08-14 22:27:27 字數 1275 閱讀 1089

今天想和大家分享乙個關於session的話題: 當瀏覽器關閉時,session就被銷毀了?

我們知道session是jsp的九大內建物件(也叫隱含物件)中的乙個,它的作用是可以保

存當前使用者的狀態資訊,初學它的時候,認為session的生命週期是從開啟乙個瀏覽器窗

口傳送請求到關閉瀏覽器視窗,但其實這種說法是不正確的!下面就具體的去解釋:

當使用者第一次訪問web應用中支援session的某個網頁時,就會開始乙個新的session,

那麼接下來當使用者瀏覽這個web應用的不同網頁時,始終處於乙個session中

再詳細些:

以上就是session的執行機制,但是還沒有提到session的生命週期,再往下了解!

其實讓session結束生命週期,有以下兩種辦法:

我們知道session是存在於伺服器端的,當把瀏覽器關閉時,瀏覽器並沒有向伺服器傳送

任何請求來關閉session,自然session也不會被銷毀,但是可以做一點努力,在所有的

客戶端頁面裡使用js的window.onclose來監視瀏覽器的關閉動作,然後向伺服器傳送一

個請求來關閉session,但是這種做法在實際的開發中也是不推薦使用的,最正常的辦法

就是不去管它,讓它等到預設的時間後,自動銷毀

那麼為什麼當我們關閉瀏覽器後,就再也訪問不到之前的session了呢?

其實之前的session一直都在伺服器端,而當我們關閉瀏覽器時,此時的cookie是存在

於瀏覽器的程序中的,當瀏覽器關閉時,cookie也就不存在了。

其實cookie有兩種:

而session的cookie是存在於瀏覽器的程序中,那麼這種cookie我們稱為會話cookie,

當我們重新開啟瀏覽器視窗時,之前的cookie中存放的sessionid已經不存在了,此時

伺服器從httpservletrequest物件中沒有檢查到sessionid,伺服器會再傳送乙個新的存

有sessionid的cookie到客戶端的瀏覽器中,此時對應的是乙個新的會話,而伺服器上

原先的session等到它的預設時間到之後,便會自動銷毀。

ps:當在同乙個瀏覽器中同時開啟多個標籤,傳送同乙個請求或不同的請求,仍是同乙個session;

當不在同乙個視窗中開啟相同的瀏覽器時,傳送請求,仍是同乙個session;

當使用不同的瀏覽器時,傳送請求,即使傳送相同的請求,是不同的session;

當把當前某個瀏覽器的視窗全關閉,再開啟,發起相同的請求時,就是本文所闡述的,是不同的session,但是它和session的生命週期是沒有關係的.

瀏覽器關閉了是否session就自動消失了呢

在談論session機制的時候,常常聽到這樣一種誤解 只要關閉瀏覽器,session就消失了 其實可以想象一下會員卡的例子,除非顧客主動對店家提出銷卡,否則店家絕對不會輕易刪除顧客的資料。對session來說也是一樣的,除非程式通知伺服器刪除乙個session,否則伺服器會一直保留,程式一般都是在使...

瀏覽器關閉後,Session就銷毀了嗎?

話題 當瀏覽器關閉後,session就銷毀了嗎?答案 存在於瀏覽器上的唯一識別符號jsessionid sessionid 消失了,但是伺服器中存放的sessionid並沒有立馬銷毀。分析 我們知道session是jsp的九大內建物件 也叫隱含物件 中的乙個,它的作用是可以儲存當前使用者的狀態資訊,...

關閉瀏覽器後Session就銷毀了嗎

存在於瀏覽器上的唯一識別符號jsessionid sessionid 消失了,但是伺服器中存放的sessionid並沒有立馬銷毀。我們知道session是jsp的九大內建物件 也叫隱含物件 中的乙個,它的作用是可以儲存當前使用者的狀態資訊,初學它的時候,認為session的生命週期是從開啟乙個瀏覽器...