Servlet p6 HttpSession對象

来源:https://www.cnblogs.com/zh-Note/archive/2023/07/04/17526250.html
-Advertisement-
Play Games

# HttpSession對象 **HttpSession**對象是javax.servlet.http.HttpSession的實例,該**介面**井不像HttpServletRequest或 HttpServletResponse還存在一個父介面,該介面只是一個純粹的介面。這因為session本 ...


HttpSession對象

HttpSession對象是javax.servlet.http.HttpSession的實例,該介面井不像HttpServletRequest或
HttpServletResponse還存在一個父介面,該介面只是一個純粹的介面。這因為session本身就屬於HTTP協議的
範疇。

對於伺服器而言,每個來連接到它的客戶端都是一個Session,Servlet容器使用此介面創建HTTP客戶端和HTTP伺服器之間的會話。會話將保留指定的時間段,跨多個連接或來自用戶的頁面請求。一個會話通常對應於一個用戶,該用戶可能多次訪問一個站點。可以通過此介面查看和操作有關的某個會話的信息,比如會話標識符、創建時間和最後一次訪問時間。在整個Session中,最重要的就是屬性的操作。

Session 無論客戶端還是伺服器端都可以感知到,若重新打開一個新的瀏覽器,則無法取得之前設置的Session,因為每一個Session只保存在當前的瀏覽器中,併在相關的頁面取得。

Session 的作用就是為了標識一次會話,或者說確認一個用戶;並且在一次會話(一個用戶的多次請求)期間共用數據,我們可以通過 request.getSession()方法,來獲取當前會話的Session對象。

@WebServlet("/ser01")
public class Session01 extends HttpServlet {
    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //獲取Session對象,獲取Session對象時,會先判斷Session對象是否存在,如果存在則獲取,不存在,則創建
        HttpSession session = req.getSession();

        //獲取Session對象的會話標識符
        System.out.println(session.getId());

        //獲取Session對象的創建時間
        System.out.println(session.getCreationTime());

        //獲取最後一次訪問時間
        System.out.println(session.getLastAccessedTime());

        //判斷是否是新的Session對象
        System.out.println(session.isNew());
    }
}

標識符JSESSIONID

Session既然是為了標識一次會話,那麼此次會話就應該有一個唯一的標誌,這個標誌就是sessionld。

每當一次請求到達伺服器,如果開啟了會話(訪問了session),伺服器第一步會查看是否從客戶端回傳一個
名為JSESSIONID的cookie,如果沒有則認為這是一次新的會話,會創建一個新的session對象,並用唯一的
sessionld為此次會話做一個標誌。如果有JESSIONID這個cookie回傳,伺服器則會根據JSESSIONID這個值去查
看是否含有id為SESSION值的session對象,如果沒有則認為是一個新的會話,重新創建個新的session對像,
並標誌此次會話:如果找到了相應的session對象,則認為是之前標誌過的一次會話,返回該session對像,數
據達到共用。

這裡提到一個叫做JSESSIONID的cookie,這是一個比較特殊的cookie,當用戶請求伺服器時,如果訪問了
session,則伺服器會創建一個名為JSESSIONID,值為獲取到的session(無論是獲取到的還是新創建的)的
sessionld的cookie對象,並添加到response對象中,響應給客戶端,有效時間為關閉瀏覽器。

所以Session的底層依賴Cookie來實現。

Session域對象

Session 用來表示一次會話,在一次會話中數據是可以共用的,這時 session 作為域對象存在,可以通過 setAttribute(name, value)方法向域對象中添加數據,通過 getAttribute(name)從域對象中獲取數據,可以通過 removeAtttribute(name)方法從域對象中移除數據。

//獲取Session對象
HttpSession session = req.getSession();       
//設置Session域對象
session.setAttribute("uname", "admin");

//獲取指定名稱的Session域對象
String uname = (String) request.getSession().getAttribute("uname");

//移除Session域對象
session.removeAttribute("uname");

數據存儲在 Session 域對象中,當域對象不存在了,或者是兩個不一樣的 Session對象時,數據也就不能共用了。

Session對象的銷毀

預設到期時間

當客戶端第一次請求 servlet 並且操作 session 時, session 對象生成,Tomcat 中 session 預設的存活時間為 30 min,即你不操作界面的時間,一旦有操作,session就會重新計時。

那麼 session 的預設時間可以改嗎?答案是肯定的。

可以在 Tomcat 的 conf目錄下的 web.xml 文件中進行修改。

<!-- session 預設的最大不活動時間。單位:分鐘。-->
<session-config>
    <session-timeout>30</session-timeout>
</session-config>

自己設定到期時間

當然除了以上的修改方式外,我們也可以在程式中自己設定 session 的生命周期,通過 session.setMaxInactiveInterval(int) 來設定 session 的最大不活動時間,單位為秒。

//獲取 session對象
HttpSession session = req.getSession();
//設置Session對象的最大不活動時間
session.setMaxInactiveInterval(15);//15秒失效

當然我們也可以通過 getMaxInactiveInterval() 方法來查看當前 Session對象 的最大不活動時間。

//獲取Session對象的最大不活動時間
System.out.println("Session對象的最大不活動時間" + session.getMaxInactiveInterval());

立刻失效

或者我們也可以通過 session.invalidate( ) 方法讓 session 立刻失效。

session.invalidate();

關閉瀏覽器

從前面的JESSION可知道,session的底層依賴cookie實現,並且該cookie的有效時間為關閉瀏覽器,從
而session在瀏覽器關閉時也相當於失效了(因為沒有JSESSION再與之對應)。

關閉伺服器

當關閉伺服器時,session銷毀。

Session失效則意味著此次會話結束,數據共用結束。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、推送作用 推送作用我就不廢話了,能做推送的都知道作用,直接上乾貨。 二、unipush 快速開通 Dcloud 開發者實名認證註冊賬號,綁定對應的 app 信息。 uni-push產品有2個入口: 通過 HBuilderX(3.5.1及其以上版本)進入 打開 HBuilderX,雙擊項目中的 “ ...
  • 腳手架大家一定都不陌生,比如我們經常使用的 vue-cli、create-react-app,它可以幫助我們快速的初始化一個項目,無需從零配置,極大的方便我們的開發。到這裡你可能會疑惑,既然市面上有成熟的腳手架,為什麼需要寫一個屬於自己的腳手架呢。因為公共腳手架雖然強大,但並不能滿足我們的實際開發需... ...
  • ![](https://img2023.cnblogs.com/blog/3076680/202307/3076680-20230703164452820-448646113.png) # 1. 物理主機 ## 1.1. 以前數據中心硬體就是建立在單個物理機器的高可靠性上的 ## 1.2. 如今通過 ...
  • 環境:Windows10_x64 Python版本 :3.9.2 Pillow版本:9.1.1 寫的博客文章被轉載且不註明出處的情況時有發生,甚至有部分轉載者將文章配圖添加自己的水印!為了保護作者勞動成果,添加水印是一個可選項。 今天記錄下Windows10環境下使用python3.9簡單實現批量添 ...
  • 某日二師兄參加XXX科技公司的C++工程師開發崗位第31面: > 面試官:什麼是鎖?有什麼作用? > > 二師兄:在C++中,鎖(Lock)是一種同步工具,用於保護共用資源,防止多個線程同時訪問,從而避免數據競爭和不一致。 > > 面試官:有哪些鎖? > > 二師兄:從種類上分,可以分為普通鎖、讀寫 ...
  • ### 歡迎訪問我的GitHub > 這裡分類和彙總了欣宸的全部原創(含配套源碼):[https://github.com/zq2599/blog_demos](https://github.com/zq2599/blog_demos) ### 本篇概覽 - 本文是《JavaCV的攝像頭實戰》系列的 ...
  • ### 前言 上一篇我們從0到1用`pb`開發了一個`helloworld`程式,併成功將開發的程式編譯打包並且製作了安裝包。 程式員最討厭的莫過於寫文檔和別人不寫註釋。 不知道大家會不會和我一樣,在找bug時,有段代碼,心中不知默默的罵了它多少遍。 哪個sx寫的這代碼,研究了一段時間發現,原來那s ...
  • 1、轉成圖片的方式和轉成html,都存在一定的問題,比如轉圖片的都是存在要處理多圖片的問題,轉html存在複雜樣式丟失的問題。比較好的一種做法就是即將文檔里的內容都生成成圖片(很可能是多張圖片),然後將生成的圖片全都放到一個html頁面里 ,用html+css來保持樣式並實現多張圖片展示,再將htm... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...