搜尋
首頁web前端js教程Cookie和Session的差異總結

Cookie和Session的差異總結

Apr 11, 2019 am 11:14 AM
javascript快取

這篇文章帶給大家的內容是關於Cookie和Session的區別總結,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

HTTP無狀態協定

HTTP無狀態協議,是指協定對於交易處理沒有記憶能力。缺少狀態意味著如果後續處理需要前面的訊息,則它必須重傳,這可能導致每次連接傳送的資料量增加。另一方面,在伺服器不需要先前資訊時它的應答就較快。
簡介
客戶端與伺服器進行動態互動的Web應用程式出現之後,HTTP無狀態的特性嚴重阻礙了這些應用程式的實作,畢竟互動是需要承前啟動後的,簡單的購物車程式也要知道使用者到底在之前選擇了什麼商品。於是,兩個用來維持HTTP連線狀態的技術就應運而生了,一個是Cookie,而另一個則是SessionHTTP本身是一個無狀態的連接協議,為了支援客戶端與伺服器之間的交互,我們就需要透過不同的技術為交互儲存狀態,而這些不同的技術就是Cookie和Session了

Cookie是透過客戶端保持狀態的解決方案。從定義上來說,Cookie就是由伺服器發給客戶端的特殊訊息,而這些訊息以文字檔案的方式存放在客戶端,然後客戶端每次向伺服器發送請求的時候都會帶上這些特殊的訊息。讓我們說得更具體一點:當使用者使用瀏覽器造訪一個支援Cookie的網站的時候,使用者會提供包括使用者名稱在內的個人資訊並且提交至伺服器;接著,伺服器在向客戶端回傳相應的超文字的同時也會發回這些個人訊息,當然這些訊息並不是存放在HTTP回應體(Response Body)中的,而是存放在HTTP回應頭(Response Header);當客戶端瀏覽器接收到來自伺服器的回應之後,瀏覽器會將這些資訊存放在一個統一的位置,對於Windows作業系統而言,我們可以從: [系統盤]:Documents and Settings[使用者名稱]Cookies目錄中找到儲存的Cookie;自此,客戶端再傳送請求請求的時候,都會把對應的Cookie再傳回伺服器。而這次,Cookie訊息則存放在HTTP請求頭(Request Header)了。 斜體文字

發展
有了Cookie這樣的技術實現,伺服器在接收到來自客戶端瀏覽器的請求之後,就能夠透過分析存放於請求頭的Cookie得到客戶端特有的信息,從而動態生成與該客戶端相對應的內容。通常,我們可以從許多網站的登入介面中看到「請記住我」這樣的選項,如果你勾選了它之後再登錄,那麼在下一次訪問該網站的時候就不需要進行重複而繁瑣的登錄動作了,而這個功能就是透過Cookie實現的。

與Cookie相對的一個解決方案是Session,它是透過伺服器來保持狀態的。由於Session這個詞彙包含的語意很多,因此需要在這裡明確一下 Session的意思。首先,我們通常都會把Session翻譯成會話因此我們可以把客戶端瀏覽器與伺服器之間一系列互動的動作稱為一個 Session。從這個語意出發,我們會提到Session持續的時間,會提到在Session過程中進行了什麼操作等等;其次,Session指的是伺服器端為客戶端所開闢的儲存空間,在其中保存的資訊就是用於保持狀態。從這個語意出發,我們會提到往Session存放什麼內容,如何根據鍵值從 Session中取得符合的內容等。
要使用Session,第一步當然是建立Session了。那麼Session在何時創建呢?當然還是在伺服器端程式運行的過程中創建的,不同語言實現的應用程式有不同創建Session的方法,而在Java中是透過呼叫HttpServletRequest的getSession方法(使用true作為參數)來建立的。在創建了Session的同時,伺服器會為該Session產生唯一的Session id,而這個Session id在隨後的請求中會被用來重新獲得已經創建的Session;在Session被創建之後,就可以調用Session相關的方法在Session中增加內容了,而這些內容只會保存在伺服器中,發到客戶端的只有Session id;當客戶端再次發送請求的時候,會將這個Session id帶上,伺服器接受到請求之後就會依據Session id找到對應的Session,從而再次使用。正是這樣一個過程,使用者的狀態也就得以維持了。
綜上所述,HTTP本身就是一個無狀態的連線協議,為了支援客戶端與伺服器之間的交互,我們就需要透過不同的技術為交互儲存狀態,而這些不同的技術就是Cookie和Session了

Cookie

存放位置
cookie資料存放在客戶的瀏覽器上,伺服器能夠知道其中的資訊;
使用方式
如果在瀏覽器中不設定過期時間,cookie被保存在記憶體中,生命週期隨瀏覽器的關閉而結束,這種cookie簡稱會話cookie 。

如果在瀏覽器中設定了cookie的過期時間,cookie被保存在硬碟中,關閉瀏覽器後,cookie資料仍然存在,直到過期時間結束才消失

儲存
單一cookie儲存的資料不能超過4KB,一個伺服器最多在客戶端瀏覽器上儲存20個Cookie,一個瀏覽器最多保存300個Cookie
cookie只能保存字串類型,以文字的方式
應用場景
cookie技術有4個元件:在HTTP回應報文中有一個cookie首部行;在HTTP請求訊息中有一個cookie首部行;在用戶端系統中保留有一個cookie文件,並由用戶的瀏覽器進行管理;位於Web站點的一個後端資料庫

Cookie和Session的差異總結

判斷使用者是否有登陸網站,以便下次登入時能夠實現自動登入(或記住密碼)。

如果我們刪除cookie,則每次登入必須從新填寫登入的相關資訊。

儲存上次登入的時間等資訊。儲存上次查看的頁面 瀏覽計數訪問
cookie中如果設定了路徑參數,那麼同一個網站中不同路徑下的cookie互相是無法存取的。
缺點

Cookie和Session的差異總結

大小受限、使用者可以操作(停用)cookie,使功能受限、、安全性較低、有些狀態不可能儲存在客戶端、每次存取都要傳送cookie給伺服器,浪費頻寬、cookie資料有路徑(path)的概念,可以限制cookie只屬於某個路徑下。

其他

Cookie和Session的差異總結

Cookie和Session的差異總結

攜帶cookie進行資料請求

cookie資料始終在同源的http請求中攜帶(即使不需要),即cookie在瀏覽器和伺服器間來回傳遞;
每次要求一個新的頁面的時候cookie都會被發送過去,這樣無形中浪費了頻寬,另外cookie還需要指定作用域,不可跨域呼叫。

Session

存放位置
session資料放在伺服器上,客戶端不知道其中的資訊,不過session可以透過特殊的方式做持久化管理(memcache, redis);
使用方式

session在什麼時候創建,以及session一致性問題

session會在一定時間內保存在伺服器上,當訪問增多,會比較佔用你伺服器的效能,考慮到減輕伺服器效能方面,應使用cookie
當程式需要為某個客戶端的請求建立一個session時,伺服器首先檢視這個客戶端的請求裡是否已包含了一個session標識(稱為session id),如果已包含則表示以前已經為此客戶端創建過session,伺服器就按照session id把這個session檢索出來使用檢索不到,會新建一個),如果客戶端請求不包含session id,則為客戶端建立一個session並且產生一個與此session相關聯的session id, session id的值應該是一個既不會重複,又不容易被找到規律以仿造的字串,這個session id將會在本次回應中傳回給客戶端保存。儲存這個session id的方式可以採用cookie,這樣在互動過程中瀏覽器可以自動的按照規則把這個識別傳送給伺服器。

通常使用cookie方式儲存sessionid到客戶端,在互動中瀏覽器依照規則將sessionid傳送給伺服器。如果使用者停用cookie,則要使用URL重寫,可以透過response.encodeURL(url)
進行實作;API對encodeURL的結束為,當瀏覽器支援Cookie時,url不做任何處理;當瀏覽器不支援Cookie的時候,將會重寫URL將SessionID拼接到存取地址後。

儲存
session大小沒有限制
session中保存的是物件,session透過類似與Hashtable的資料結構來保存,能支援任何類型的物件(session中可含有多個物件)
應用場景
Session用於保存每個使用者的專用訊息,變數的值保存在伺服器端,透過SessionID來區分不同的客戶。
  1. 線上商城中的購物車
  2. 儲存使用者登入資訊
  3. 將某些資料放入session中,供同一使用者的不同頁面使用
  4. 防止使用者非法登入
存取
session不能區分路徑,同一個使用者在造訪一個網站期間,所有的session在任何一個地方都可以存取。

缺點

Session保存的東西越多,就越佔用伺服器內存,對於用戶在線人數較多的網站,伺服器的內存壓力會比較大、依賴於cookie(sessionID保存在cookie),如果停用cookie,則要使用URL重寫,不安全、創建Session變數有很大的隨意性,可隨時調用,不需要開發者做精確地處理,所以,過度使用session變數將會導致程式碼不可讀而且不好維護。

以上是Cookie和Session的差異總結的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:segmentfault。如有侵權,請聯絡admin@php.cn刪除
JavaScript框架:為現代網絡開發提供動力JavaScript框架:為現代網絡開發提供動力May 02, 2025 am 12:04 AM

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

JavaScript,C和瀏覽器之間的關係JavaScript,C和瀏覽器之間的關係May 01, 2025 am 12:06 AM

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr

node.js流帶打字稿node.js流帶打字稿Apr 30, 2025 am 08:22 AM

Node.js擅長於高效I/O,這在很大程度上要歸功於流。 流媒體匯總處理數據,避免內存過載 - 大型文件,網絡任務和實時應用程序的理想。將流與打字稿的類型安全結合起來創建POWE

Python vs. JavaScript:性能和效率注意事項Python vs. JavaScript:性能和效率注意事項Apr 30, 2025 am 12:08 AM

Python和JavaScript在性能和效率方面的差異主要體現在:1)Python作為解釋型語言,運行速度較慢,但開發效率高,適合快速原型開發;2)JavaScript在瀏覽器中受限於單線程,但在Node.js中可利用多線程和異步I/O提升性能,兩者在實際項目中各有優勢。

JavaScript的起源:探索其實施語言JavaScript的起源:探索其實施語言Apr 29, 2025 am 12:51 AM

JavaScript起源於1995年,由布蘭登·艾克創造,實現語言為C語言。 1.C語言為JavaScript提供了高性能和系統級編程能力。 2.JavaScript的內存管理和性能優化依賴於C語言。 3.C語言的跨平台特性幫助JavaScript在不同操作系統上高效運行。

幕後:什麼語言能力JavaScript?幕後:什麼語言能力JavaScript?Apr 28, 2025 am 12:01 AM

JavaScript在瀏覽器和Node.js環境中運行,依賴JavaScript引擎解析和執行代碼。 1)解析階段生成抽象語法樹(AST);2)編譯階段將AST轉換為字節碼或機器碼;3)執行階段執行編譯後的代碼。

Python和JavaScript的未來:趨勢和預測Python和JavaScript的未來:趨勢和預測Apr 27, 2025 am 12:21 AM

Python和JavaScript的未來趨勢包括:1.Python將鞏固在科學計算和AI領域的地位,2.JavaScript將推動Web技術發展,3.跨平台開發將成為熱門,4.性能優化將是重點。兩者都將繼續在各自領域擴展應用場景,並在性能上有更多突破。

Python vs. JavaScript:開發環境和工具Python vs. JavaScript:開發環境和工具Apr 26, 2025 am 12:09 AM

Python和JavaScript在開發環境上的選擇都很重要。 1)Python的開發環境包括PyCharm、JupyterNotebook和Anaconda,適合數據科學和快速原型開發。 2)JavaScript的開發環境包括Node.js、VSCode和Webpack,適用於前端和後端開發。根據項目需求選擇合適的工具可以提高開發效率和項目成功率。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)