cookie的原理和一些現象

2021-08-17 15:55:29 字數 2581 閱讀 3726

就好比白雲和黑土兩人在一起,規定以後兩人溝通統一用兩人約定好的語言去交流,白雲伸出左手,那麼黑土看到這個動作就會做出判斷,哦,原來是要捶腿,於是立馬撲上去捶腿。白雲伸右手,黑土一看,媽呀,這是要喝水的節奏,於是立馬遞水過去,此時白雲伸出左腳,黑土立馬親一口。兩人的溝通正是因為遵循了彼此之間的約定,所以才變得很容易理解與高效執行。

http協議也一樣,該協議的參與者是客戶端(白雲)與伺服器端(黑土)。

正是有了http協議,客戶端與伺服器端之間的通訊才變得輕鬆易懂,試想,如果白雲和黑土事先沒有按照約定去規範自己的溝通方式,那白雲伸出左腳,估計黑土大叔還以為要踢自己呢。

接下裡,我們就來看看http協議都有哪些特點?

1、支援客戶/伺服器模式;

2、簡單快速

3、靈活

4、無連線

5、無狀態。

支援客戶端/伺服器端的模式:簡單來講就是支援兩個人通訊,即支援白雲和黑土這兩個人相互通話。

簡單便捷:就像白雲和黑土的溝通,伸左手,伸右手這麼簡單。http協議也是一樣,無論是客戶端請求還是服務端響應,設定好對應的訊息頭,方法,訊息體,就能夠傳達給對方,並且雙都能理解對方的意思。

靈活的原因在於http允許傳輸任意型別的資料物件。傳輸的型別由content-type加以標記即可。

無連線指的是客戶端請求服務端,服務端響應完成之後就自動斷開連線本次鏈結。就好比白雲伸左手,黑土就過來錘腿,錘完自動走開去忙別的一樣。

無狀態指的是客戶端請求服務端,服務端響應完成之後不會記錄任何本次連線通訊的資料。就好比白雲伸左手,黑土就過來錘腿,錘完腿,你問黑土大叔,你們捶腿的時候都說了些啥,黑土回答:我啥都不記得了。

當然,http協議遠遠不止這麼多,具體的我們後期再說,有了上面的http協議的知識,我們就要引出我們的cookie了。

上面提到,白雲和黑土之間約定了自己的溝通方式,很高效也很簡單,但是他們的溝通也有一定的問題,那就是http協議的無狀態,也就是,黑土大叔給白雲捶腿的時候不知道兩人之間說了什麼,他腦袋不好使,記不住,只記得個別事情,這可不是什麼好事兒,比如,捶腿的時候,白雲告訴黑土,你手勁兒太大了,捶的我好疼,輕一點,黑頭大叔聽完,立馬手勁兒放小一點,然後錘完走開去忙別的。黑土剛走,白雲又伸出左手,黑土趕緊過來捶腿,還是重重的捶著腿,白雲急眼了,剛剛不是跟你說過了嗎?手放輕點,捶的老娘腿都麻了,黑土大叔一臉懵逼,親,我真的不記得了。

怎麼辦?

照這樣下去,黑土大叔得把白雲氣死不可,於是有人提出個建議,白雲每次伸手或者伸腿的時候扔出一張紙條,紙條上面記載一些她個人的一些要求,黑土大叔拿到紙條呢,邊看紙條邊跑來做出相應的響應操作,響應完成後就把紙條還給白雲,為的是讓白雲下次找他的時候可以寫上要求同時將這個紙條扔給黑土。

這個辦法雖然有些不文雅,倒也是解決了黑土大叔啥都記不住的問題。

得,上面的這張紙條其實就是我們今天要講的cookie,客戶端向伺服器發起請求的時候,客戶端帶上cookie去請求服務端,有了這個cookie,就能記住上一次請求的狀態和相關資訊,使通訊有了狀態,有記憶。

很多人在儲存一些資料的時候不推薦使用cookie,原因在於每次客戶端請求服務端的時候,都會帶上cookie資訊,cookie雖然通常乙個value值只有4k大小,但是量一旦上來就會很費頻寬。

那麼接下來我們解釋下cookie的一些基本工作原理:

cookie主要是通過報頭httpheader來傳遞資料。也就是在請求頭和訊息頭裡面傳遞資料。cookie機制定義了兩種報頭:set-cookie報頭和cookie報頭。set-cookie存在於伺服器響應的訊息頭中。而cookie則存在於客戶端請求的訊息頭中。

cookie的執行流程如下:

(1)客戶端在瀏覽器的位址列中鍵入web伺服器的url,瀏覽器傳送讀取網頁的請求。

(2)伺服器接收到請求後,產生乙個set-cookie報頭,放在http報文中一起回傳客戶端,發起一次會話。

(3)客戶端收到應答後,若要繼續該次會話,則將set-cook-ie中的內容取出,形成乙個cookie.txt檔案儲存在客戶端計算機裡。

(4)當客戶端再次向伺服器發出請求時,瀏覽器先在電腦裡尋找對應該**的cookie.txt檔案。如果找到,則根據此cookie.txt產生cookie報頭,放在http請求報文中發給伺服器。

(5)伺服器接收到包含cookie報頭的請求,檢索其cookie中與使用者有關的資訊,生成乙個客戶端所請示的頁面應答傳遞給客戶端。 瀏覽器的每一次網頁請求,都可以傳遞已存在的cookie檔案,例如,瀏覽器的開啟或重新整理網頁操作。

這就是cookie的基本工作原理。

另外,在php中設定cookie有兩種方式:

1 setcookie函式的呼叫

2session_start函式的呼叫

這裡稍微解釋下session_start做的工作,session_start()一旦寫上,伺服器端就會在伺服器上生成乙個檔名叫做session_id的檔案,並同時向客戶端傳送set-cookie報頭,內容為phpsessid=伺服器上儲存session的檔名,即session_id,客戶端接到響應就會生成cookie檔案,也就是session_start裡面其實包含了setcookie的操作,只是沒有setcookie那麼靈活而已。

session和cookie的一些區別?

session和cookie都是會話 seesion 跟蹤技術。cookie通過在客戶端記錄資訊確定使用者身份,session通過在伺服器端記錄資訊確定使用者身份。但是session的實現依賴於cookie,sessionid session的唯一標識需要存放在客戶端 cookie 和session...

Cookie的一些操作

有關cookie的一些操作。1 取得cookie的相關資訊 cookie cookies request.getcookies string username string password if cookies null 2 將登陸使用者的名和密碼儲存到cookie中 在伺服器端 cookie c...

Cookie的一些筆記

cookie 餅乾 即乙份資料,由伺服器給客戶端,且儲存在客戶端的乙份很小的資料 在程式中,不同的客戶端會產生許多會話,故而,會話的跟蹤就顯得尤為重要。理論上,乙個客戶端的所有操作都應該屬於同乙個會話,不同使用者的操作與會話不能混淆組合。例如,你購物車內新增了乙個商品,隔了10天,你又新增了乙個商品...