JWT和cookie/session的區別及優缺點


存儲位置

三者都是應用在web中對http無狀態協議的補充,達到狀態保持的目的

 

cookiecookie中的信息是以鍵值對的形式儲存在瀏覽器中,而且在瀏覽器中可以直接看到數據。

 

sessionsession存儲在服務器中,然后發送一個cookie存儲在瀏覽器中,cookie中存儲的是session_id,之后每次請求服務器通過session_id可以獲取對應的session信息

 

JWTJWT存儲在瀏覽器的storage或者cookie中。由服務器產生加密的json數據包括:header,payload和signature三部分組成。header中通常來說由token的生成算法和類型組成;payload中則用來保存相關的狀態信息;signature部分由header,payload,secret_key三部分加密生成。 注意,不要在JWT的payload或header中放置敏感信息,除非它們是加密的。

 

優缺點

cookie:

  • 優點:
  1. 結構簡單。cookie是一種基於文本的輕量結構,包含簡單的鍵值對。
  2. 數據持久。雖然客戶端計算機上cookie的持續時間取決於客戶端上的cookie過期處理和用戶干預,cookie通常是客戶端上持續時間最長的數據保留形式。
  • 缺點:
  1. 大小受到限制。大多數瀏覽器對 cookie 的大小有 4096 字節的限制,盡管在當今新的瀏覽器和客戶端設備版本中,支持 8192 字節的 cookie 大小已愈發常見。
  2. 非常不安全。cookie將數據裸露在瀏覽器中,這樣大大增大了數據被盜取的風險,所有我們不應該將中要的數據放在cookie中,或者將數據加密處理。
  3. 容易被csrf攻擊。可以設置csrf_token來避免攻擊。

session:

  • 優點:
  1. session的信息存儲在服務端,相比於cookie就在一定程度上加大了數據的安全性;相比於jwt方便進行管理,也就是說當用戶登錄和主動注銷,只需要添加刪除對應的session就可以,這樣管理起來很方便。
  • 缺點:
  1. session存儲在服務端,這就增大了服務器的開銷,當用戶多的情況下,服務器性能會大大降低。
  2. 因為是基於cookie來進行用戶識別的, cookie如果被截獲,用戶就會很容易受到跨站請求偽造的攻擊。
  3. 用戶認證之后,服務端做認證記錄,如果認證的記錄被保存在內存中的話,這意味着用戶下次請求還必須要請求在這台服務器上,這樣才能拿到授權的資源,這樣在分布式的應用上,會限制負載均衡和集群水平拓展的能力。

JWT:

  • 優點:
  1. 因為json的通用性,jwt可以支持跨語言請求,像JAVA,JavaScript,PHP等很多語言都可以使用。
  2. 因為有了payload部分,所以JWT可以在自身存儲一些其他業務邏輯所必要的非敏感信息。
  3. 便於傳輸,JWT的構成非常簡單,字節占用很小,所以它是非常便於傳輸的。
  4. 不需要在服務端保存會話信息, 利於服務器橫向拓展。
  • 缺點:
  1. 登錄狀態信息續簽問題。比如設置token的有效期為一個小時,那么一個小時后,如果用戶仍然在這個web應用上,這個時候當然不能指望用戶再登錄一次。目前可用的解決辦法是在每次用戶發出請求都返回一個新的token,前端再用這個新的token來替代舊的,這樣每一次請求都會刷新token的有效期。但是這樣,需要頻繁的生成token。另外一種方案是判斷還有多久這個token會過期,在token快要過期時,返回一個新的token。
  2. 用戶主動注銷。JWT並不支持用戶主動退出登錄,客戶端在別處使用token仍然可以正常訪問。為了支持注銷,我的解決方案是在注銷時將該token加入到服務器的redis黑名單中。
  3. JWT與OAuth的區別
  4. > 這兩個概念總有人用混淆,所以一起介紹了。

    OAuth2是一種授權框架,用在使用第三方賬號登錄的情況(比如使用weibo, qq, github登錄某個app)
    JWT是一種認證協議,用在前后端分離,需要簡單的對后台API進行保護時使用。 > 無論使用哪種方式切記用HTTPS來保證數據的安全性;


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM