Cookie和Session的區別

2022-10-09 09:24:15 字數 2197 閱讀 6511

session和cookie的區別:

cookie是把使用者的資料寫給使用者的瀏覽器,瀏覽器儲存(可以儲存多個)

session 把使用者的資料寫到獨佔session中,伺服器端儲存(儲存重要的資訊,減少伺服器資源的浪費)

session物件由服務建立

cookie和session都是用來跟蹤瀏覽器使用者身份的會話方式

cookie的工作原理

(1)瀏覽器端第一次傳送請求到伺服器端

(2)伺服器端建立cookie,該cookie中包含使用者的資訊,然後將該cookie傳送到瀏覽器端

(3)瀏覽器端再次訪問伺服器端時會攜帶伺服器端建立的cookie

(4)伺服器端通過cookie中攜帶的資料區分不同的使用者

session的工作原理

(1)瀏覽器端第一次傳送請求到伺服器端,伺服器端建立乙個session,同時會建立乙個特殊的cookie(name為jsessionid的固定值,value為session物件的id),然後將該cookie傳送至瀏覽器端

(2)瀏覽器端傳送第n(n>1)次請求到伺服器端,瀏覽器端訪問伺服器端時就會攜帶該name為jsessionid的cookie物件

(3)伺服器端根據name為jsessionid的cookie的value(sessionid),去查詢session物件,從而區分不同使用者。

name為jsessionid的cookie不存在(關閉或更換瀏覽器),返回1中重新去建立session與特殊的cookie

name為jsessionid的cookie存在,根據value中的sessionid去尋找session物件

value為sessionid不存在(session物件預設存活30分鐘),返回1中重新去建立session與特殊的cookie

value為sessionid存在,返回session物件

cookie資料儲存在客戶端,session資料儲存在服務端。

session

簡單的說,當你登陸乙個**的時候,如果web伺服器端使用的是session,那麼所有的資料都儲存在伺服器上,客戶端每次請求伺服器的時候會傳送當前會話sessionid,伺服器根據當前sessionid判斷相應的使用者資料標誌,以確定使用者是否登陸或具有某種許可權。由於資料是儲存在伺服器上面,所以你不能偽造。

cookie

sessionid是伺服器和客戶端連線時候隨機分配的,如果瀏覽器使用的是cookie,那麼所有資料都儲存在瀏覽器端,比如你登陸以後,伺服器設定了cookie使用者名稱,那麼當你再次請求伺服器的時候,瀏覽器會將使用者名稱一塊傳送給伺服器,這些變數有一定的特殊標記。伺服器會解釋為cookie變數,所以只要不關閉瀏覽器,那麼cookie變數一直是有效的,所以能夠保證長時間不掉線。

如果你能夠截獲某個使用者的cookie變數,然後偽造乙個資料報傳送過去,那麼伺服器還是 認為你是合法的。所以,使用cookie被攻擊的可能性比較大。

如果cookie設定了有效值,那麼cookie會儲存到客戶端的硬碟上,下次在訪問**的時候,瀏覽器先檢查有沒有cookie,如果有的話,讀取cookie,然後傳送給伺服器。

所以你在機器上面儲存了某個論壇cookie,有效期是一年,如果有人入侵你的機器,將你的cookie拷走,放在他機器下面,那麼他登陸該**的時候就是用你的身份登陸的。當然,偽造的時候需要注意,直接copy cookie檔案到 cookie目錄,瀏覽器是不認的,他有乙個index.dat檔案,儲存了 cookie檔案的建立時間,以及是否有修改,所以你必須先要有該**的 cookie檔案,並且要從保證時間上騙過瀏覽器

兩個都可以用來存私密的東西,session過期與否,取決於伺服器的設定。cookie過期與否,可以在cookie生成的時候設定進去。

cookie資料存放在客戶的瀏覽器上,session資料放在伺服器上

cookie不是很安全,別人可以分析存放在本地的cookie並進行cookie欺騙,如果主要考慮到安全應當使用session

session會在一定時間內儲存在伺服器上。當訪問增多,會比較占用你伺服器的效能,如果主要考慮到減輕伺服器效能方面,應當使用cookie

單個cookie在客戶端的限制是3k,就是說乙個站點在客戶端存放的cookie不能3k。

所以:將登陸資訊等重要資訊存放為session;其他資訊如果需要保留,可以放在cookie中

Session和Cookie的區別

session和cookie的區別 1 儲存的位置不同 session儲存在伺服器端的記憶體中,占用伺服器資源。cookie是儲存在客戶端。可以是瀏覽器中或者是檔案中 2 儲存的時間不同 session是關閉當前會話相關瀏覽器後自動清空。cookie是根據過期時間而會有不同。3 安全性不同 sess...

cookie和session的區別

一 cookie機制和session機制的區別 具體來說cookie機制採用的是在客戶端保持狀態的方案,而session機制採用的是在伺服器端保持狀態的方案。同時我們也看到,由於在伺服器端保持狀態的方案在客戶端也需要儲存乙個標識,所以session機制可能需要借助於cookie機制來達到儲存標識的目...

cookie和session的區別

分類 計算機網路 2011 10 21 10 43 4785人閱讀收藏 舉報 session 瀏覽器伺服器 servlet url儲存 一 cookie機制和session機制的區別 具體來說cookie機制採用的是在客戶端保持狀態的方案,而session機制採用的是在伺服器端保持狀態的方案。同時我...