圖解 Cookie

發表於2016-11-26

上一篇 圖解Http協議 ,這次繼續Http家族中的Cookie。泥瓦匠最近看到部落格園中一篇好文,如圖:

image1

這就是因為瀏覽器Cookie太大,導致請求時,請求頭域過大造成傳送失敗。下面我們們就瞭解瞭解Cookie。按著以前的思路圖文並茂哈,沒圖說個XX。

一、概述

首先從HTTP說起,Cookie是Http協議中那部分呢?

Cookie是什麼?

自問自答:Cookie是請求頭域和響應頭域的欄位。簡單地說,就是伴隨請求和響應的一組鍵值對的文字,小文字。所以稱之為”Cookie“餅乾。Cookie的生命來源於伺服器。首先是客戶端請求服務端,此時請求為第一次,無Cookie引數。這時候,服務端setCookie傳送給客戶端。記住,Cookie來源自服務端

Cookie有什麼用呢?

又自問自答:Cookie來源自服務端,當然服務於客戶。就像你我的會話,文字是在我們之間傳遞的。所以Cookie用於服務端和客戶端的會話。因為Http協議是無狀態的,Cookie就是維持會話,說白了就是傳遞資料的額外媒介。

下面我們訪問百度地址。

① 產生於服務端Response,在響應頭域

image9

② 請求頭域是這樣的:(可以在Cookie Tab頁發現,和響應有一樣的)

image12

下面泥瓦匠詳細介紹其Cookie在 請求和響應 的傳輸過程。

二、詳細介紹Cookie 傳輸過程

cookie-work

直接上圖,一一詳細解釋。順便寫個CookieServlet,模擬一下Cookie的一生。程式碼如下:

① 客戶端訪問,無服務端寫入的Cookie。

程式碼 new Cookie(“CookieName”, “CookieValue”); 可以看出服務端產生一個新的鍵值對Cookie,並且設定,說明第一次請求時,請求的請求頭域Cookie是沒有的。下面沒有CookieName=CookieValue 的Cookie值。如圖:

image2

② 服務端的Cookie傳至瀏覽器。

程式碼中 HttpServletResponse.addCookie(cookie); 這樣響應就加入了剛剛那個鍵值對Cookie。怎麼傳到瀏覽器(客戶端)呢? 同樣F12下,

image3

從圖中可得到,Cookie是通過HTTP的響應頭域傳送至瀏覽器。每個Cookie的set,都有一個對應Set-Cookie的頭。還有其中的時間代表Cookie的存活時間,HttpOnly可是此Cookie只讀模式。

③ 瀏覽器解析Cookie,儲存至瀏覽器檔案。

直接可以開啟IE的Internet選項:

image4

如圖,那個位置檔案就是我們Cookie存的地方。既然在哪裡,泥瓦匠就去找到它。

image5

開啟看看,其內容就是:存放著Cookie資訊和URL資訊及一些關於時間的。

這樣就完全搞懂了Cookie如何寫入瀏覽器。

④ 客戶端訪問,有服務端寫入的Cookie。

這樣,同樣的URL再次訪問時,F12下:

image6

不多解釋,看圖。

⑤ 伺服器獲取

服務端這時呢?只要簡單的 getCookies() 就可以獲取Cookie列表了。如圖,服務端控制檯列印如下:

image7

泥瓦匠記憶小抄:Cookie傳輸小結

① 客戶端訪問,無服務端寫入的Cookie

② 服務端的Cookie寫入瀏覽器

③ 瀏覽器解析Cookie,儲存至瀏覽器檔案

④ 客戶端訪問,有服務端寫入的Cookie

⑤ 伺服器獲取

四、談Cookie的作用到XSS(跨站點指令碼攻擊)

Cookie沒有病毒那麼危險,但包含敏感資訊。比如最常見的記住密碼,或者一些使用者經常瀏覽的網頁資料。如圖:

u34268335753625518714fm21gp0

使用者不希望這些洩露,甚至被攻擊。但事實上存在這個攻擊,究竟怎麼攻擊呢?我在 跨指令碼攻擊XSS 一文中也詳細介紹並提出解決方案。

全名:Cross Site Script,中文名:跨站指令碼攻擊。顧名思義,是指“HTML注入”纂改了網頁,插入惡意的指令碼,從而在使用者用瀏覽網頁的時候,控制使用者瀏覽器的一種攻擊。一般攻擊的套路如圖所示:

image_thumb71

五、總結

回顧全文,Cookie是HTTP協議中的一種會話機制。也明白下面兩個問題就好了

1、What 什麼是Cookie

2、How Cookie怎麼用,幹嘛用

相關文章