Web基礎瞭解版09-Cookie-Session

来源:https://www.cnblogs.com/Open-ing/archive/2019/12/28/12112676.html
-Advertisement-
Play Games

Cookie Cookie 是一種伺服器發送給瀏覽器以鍵值對形式存儲小量信息的技術。 當瀏覽器首次請求伺服器時,伺服器會將一條信息封裝成一個Cookie發送給瀏覽器,瀏覽器收到Cookie,會將它保存在記憶體中(註意這裡的記憶體是本機記憶體,而不是伺服器記憶體)或者本地文件,那之後每次向伺服器發送請求,瀏覽 ...


Cookie

Cookie

 是一種伺服器發送給瀏覽器以鍵值對形式存儲小量信息的技術。

當瀏覽器首次請求伺服器時,伺服器會將一條信息封裝成一個Cookie發送給瀏覽器,瀏覽器收到Cookie,會將它保存在記憶體中(註意這裡的記憶體是本機記憶體,而不是伺服器記憶體)或者本地文件,那之後每次向伺服器發送請求,瀏覽器都會攜帶該Cookie,伺服器就可以根據Cookie的信息來處理業務。 

Cookie的缺點

  • Cookie因為請求或響應是以報文發送,無形中增加了網路流量。

  • Cookie是明文傳送的安全性差。

  • 各個瀏覽器對Cookie有限制,使用上有局限。 

Cookie的創建

  1. 在Servlet中創建Cookie對象,並添加到Response中。

  2. 然後打開瀏覽器訪問Servlet程式,伺服器將Cookie信息發送給瀏覽器。

  3. 瀏覽器收到Cookie後會自動保存,然後我們可以在下次瀏覽器發送請求時讀取Cookie信息。

Cookie cookie = new Cookie("cookie-name", "cookie-Value");
response.addCookie(cookie);

Cookie的讀取

讀取Cookie主要指讀取瀏覽器中攜帶的Cookie。

  1. 伺服器端獲取瀏覽器傳過來的Cookie代碼:request.getCookies()

  2. 遍歷Cookie數組,獲取所有Cookie信息

Cookie值的修改

// 創建一個已存在key的Cookie對象
Cookie cookie = new Cookie("cookie-name", null);
// 修改Cookie的值
cookie.setValue("this is new value");
// 通知瀏覽器保存修改,記得再次add
response.addCookie(cookie);

Cookie的有效時間

Cookie的實例方法setMaxAge( ) 控制Cookie存活的時間,接收一個int型參數,單位:秒。

  • 參數設置為0,即:setMaxAge(0):立即失效,表示瀏覽器一收到響應後,就馬上刪除Cookie

  • 參數設置大於0:比如setMaxAge(60),表示有效的秒數60秒後,Cookie失效。

  • 參數設置小於0:比如setMaxAge(-1),表示當前會話有效。也就是關閉瀏覽器後Cookie失效,被刪除。

  • 如果不設置失效時間,預設為當前會話有效,一旦關閉瀏覽器,Cookie就失效,被刪除。

Cookie的路徑設置

Cookie的路徑是指告訴瀏覽器訪問哪些地址時應該攜帶該Cookie,也就是未設置的路徑不需要攜帶

我們通過調用Cookie的實例方法setPath()來設置,這個路徑由瀏覽器來解析。

  • / :代表伺服器的根目錄

  • 如果設置有效路徑為:/day14/abc,則:下麵幾個路徑能訪問到Cookie

    • /day14/abc 能獲取Cookie

    • /day14/xxx.xxx 不能獲取Cookie

    • /day14/abc/xxx.xxx 能獲取Cookie

    • /day14/abc/a/b/c 能獲取Cookie

  • 如果不設置,預設會在訪問“/項目名”下的資源時攜帶

    • 如:“/項目名/index.jsp” 、 “/項目名/hello/index.jsp”

Cookie cookie = new Cookie("cookie-path", "test");
// 設置Cookie的有效訪問路徑為/day14/abc/下所有資源
cookie.setPath(request.getContextPath() + "/abc");
// 通知瀏覽器保存修改
response.addCookie(cookie);

Session

由於Cookie有一很大的局限,於是Session出現了

Session的作用就是在伺服器端保存一些用戶的數據,然後傳遞給用戶一個名字為JSESSIONID的Cookie,所以本質上它也是一個Cookie,這個JESSIONID對應這個伺服器中的一個Session對象,通過它就可以獲取到保存用戶信息的Session。

Session是什麼

  • 首先Session是jsp中九大內置對象之一

  • 其次Session是一個域對象

  • 然後Session是在伺服器端用來保存用戶數據的一種技術。並且Session會話技術是基於Cookie實現的。

Session的創建和獲取

  • Session的創建時機是在request.getSession()方法第一次被調用時。

    • 補充:request.getSession()之後的調用都是獲取已經創建了的Session對象,單例模式

  • Session被創建後,同時還會有一個名為JSESSIONID的Cookie被創建。

  • 這個Cookie的預設時效就是當前會話。

Session的工作原理

  • Session被創建後,對應的Cookie被保存到瀏覽器中,之後瀏覽器每次訪問項目時都會攜帶該Cookie。

  • 當我們再次調用時會根據該JSESSIONID獲取已經存在的Cookie,而不是再創建一個新的Cookie。

  • 如果Cookie中有JSESSIONID,但是JSESSIONID沒有對應的Session存在,則會重新創建一個HttpSession對象,並重新設置JSESSIONID。

Session數據的存取

  • setAttribute 設置屬性

  • getAttribute 獲取屬性

Session的作用域是當前會話,即對應的一個瀏覽器客戶端,一個瀏覽器一個session對象非一個網頁

Session 的有效時間

Session對象在伺服器端不能長期保存,它是有時間限制的,超過一定時間沒有被訪問過的Session對象就應該釋放掉,以節約記憶體。Session的計時是從最後一次被訪問開始計時,統計其“空閑”的時間。

說明:Session對象預設的最長有效時間為30分鐘。在tomcat的conf目錄下web.xml配置文件中

設置

我們在web.xml文件中配置的Session會話超時時間是對所有Session都生效的。

setMaxInactiveInterval (int seconds) 設置用戶多長時間沒有操作之後就會Session過期。以秒為單位。

  • 如果是正數。表示用戶在給定的時間內沒有任意操作,Session會話就會過期。
  • 如果是非正數(零&負數)。表示Session永不過期。

int getMaxInactiveInterval()  獲取超時時間。以秒為單位。

invalidate()  強制失效

Session的活化和鈍化

  • Session鈍化:Session在一段時間內沒有被使用或關閉伺服器時,會將當前存在的Session對象及Session對象中的數據序列化到磁碟的過程,稱之為鈍化。

  • Session活化:Session被鈍化後,伺服器再次調用Session對象或重啟伺服器時,將Session對象及Session對象中的數據從磁碟反序列化到記憶體的過程,稱之為活化。

如果希望Session作用域中的對象也能夠隨Session鈍化過程一起序列化到磁碟上,則對象的實現類也必須實現java.io.Serializable介面。不僅如此,如果對象中還包含其他對象的引用,則被關聯的對象也必須支持序列化,

Session對象的釋放

  • Session對象空閑時間達到了目標設置的最大值,自動釋放

  • Session對象被強制失效

  • Web應用卸載

  • 伺服器進程停止

URL重寫

當Cookie在瀏覽器端可能會被禁用時,我們就可以使用URL重寫。

  • URL重寫其實就是將JSESSIONID的值以固定格式附著在URL地址後面,以實現保持JSESSIONID,進而保持會話狀態。這個固定格式是:URL;jsessionid=xxxxxxxxx

實現方式

  • response.encodeURL(String)

  • response.encodeRedirectURL(String)

//1.獲取Session對象
HttpSession session = request.getSession();
//2.創建目標URL地址字元串
String url = "targetServlet";        
//3.在目標URL地址字元串後面附加JSESSIONID的值
url = response.encodeURL(url+";jsessionid=97120112D5538009334F1C6DEADB1BE7");        
//4.重定向到目標資源
response.sendRedirect(url);

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

-Advertisement-
Play Games
更多相關文章
  • 1. 我們打開一個空的IDEA 2. 選擇Java之後點擊Next 3. 點擊Next創建空白工程 4. 給工程取個名字,叫MYIDEA 5. 勾選之後,點擊This Window按鈕 6. 我們可以看到,有了一個MYIDEA的工程 7. 我們在MYIDEA上右鍵新建一個Module 8. 選擇Sp ...
  • 本篇文章我們來講講PHP四大框架的優缺點都有哪些,讓你們在開發中更好的去選擇使用哪款PHP框架去完成項目,廢話不多說,我們一起來看看吧!! ThinkPHP ThinkPHP(FCS)是一個輕量級的中型框架,是從Java的Struts結構移植過來的中文PHP開發框架。它使用面向對象的開髮結構和MVC ...
  • 1、主題 介紹如果通過Pycharm使用本地Git集。 2、準備工作 (1)PyCharm版本為2.7或更高 (2)已經創建一個工程 (3)Git插件可用,對應可執行文件在 Git page頁面正確配置 3、創建一個Git集 按下Alt+`顯示常用的VCS命令(也可以通過主菜單VCS→VCS Ope ...
  • 先看知識點總結 一、序列操作符x in s 如果x是列表s的元素,返回True,否則Falses + t 連接兩個序列s和ts*n或者n*s 將序列s複製n次s[i] 返回s中第i元素s[i:j]或s[i:j: k] 切片,返回序列s中第i到j-1以k為步長的元素子序列12345函數len(s) 返 ...
  • 素描作為一種近乎完美的表現手法有其獨特的魅力,隨著數字技術的發展,素描早已不再是專業繪畫師的專利,今天這篇文章就來講一講如何使用python批量獲取小姐姐素描畫像。文章共分兩部分: 第一部分介紹兩種使用python生成素描畫的思路 第二部分介紹如何批量獲取素描畫 一、獲取素描圖的兩個思路 本部分介紹 ...
  • Struts2整合AJAX有2種方式: 使用type="stream"類型的<result> 使用JSON插件 使用type="stream"類型的<result> 獲取text 前端 <body> <form> 學號:<input type="text" id="no"><br /> 姓名:<in ...
  • 將pip的下載源換成國內的,速度會有很大的提升。 下麵是一些國內常用鏡像: 阿裡雲 http://mirrors.aliyun.com/pypi/simple/ 中國科技大學 https://pypi.mirrors.ustc.edu.cn/simple/ 豆瓣(douban) http://pyp ...
  • ArrayList和LinkedList的區別 步驟 1 : ArrayList和LinkedList的區別 ArrayList , 插入,刪除數據慢 LinkedList, 插入,刪除數據快 ArrayList是順序結構,所以 定位很快 ,指哪找哪。 就像電影院位置一樣,有了電影票,一下就找到位置 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...