溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

JWT與cookie和token的區(qū)別有哪些

發(fā)布時(shí)間:2021-10-08 10:00:19 來(lái)源:億速云 閱讀:152 作者:iii 欄目:開(kāi)發(fā)技術(shù)

本篇內(nèi)容主要講解“JWT與cookie和token的區(qū)別有哪些”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“JWT與cookie和token的區(qū)別有哪些”吧!

目錄
  • 一. cookie

    • A)cookie如何認(rèn)證

    • B)cookie認(rèn)證方式的不足之處

  • 二. token

    • A)token的認(rèn)證過(guò)程

    • B)token認(rèn)證方式的特點(diǎn)

  • 三. JWT

    • A)JWT介紹

    • B)JWT組成

    • C)為什么要使用JWT

    • D)JWT的Maven引入

一. cookie

A)cookie如何認(rèn)證

1.用戶輸入用戶名與密碼,發(fā)送給服務(wù)器。

2.服務(wù)器驗(yàn)證用戶名和密碼,正確的就創(chuàng)建一個(gè)會(huì)話(session),同時(shí)會(huì)把這個(gè)會(huì)話的ID保存到客戶端瀏覽器中,因?yàn)楸4娴牡胤绞菫g覽器的cookie,所以這種認(rèn)證方式叫做基于cookie的認(rèn)證方式。

3.后續(xù)的請(qǐng)求中,瀏覽器會(huì)發(fā)送會(huì)話ID到服務(wù)器,服務(wù)器上如果能找到對(duì)應(yīng)的ID的會(huì)話,那么服務(wù)器就會(huì)返回需要的數(shù)據(jù)給瀏覽器。

4.當(dāng)用戶退出登錄,會(huì)話會(huì)同時(shí)在客戶端和服務(wù)器端被銷毀。

B)cookie認(rèn)證方式的不足之處

1.服務(wù)器要為每個(gè)用戶保留session信息,連接用戶過(guò)多會(huì)造成服務(wù)器內(nèi)存壓力過(guò)大。

2.適合單一域名,不適合第三方請(qǐng)求。

二. token

A)token的認(rèn)證過(guò)程

1.用戶輸入用戶名和密碼,發(fā)送給服務(wù)器。

2.服務(wù)器驗(yàn)證用戶名和密碼,正確的話就返回一個(gè)簽名過(guò)的token(token 可以認(rèn)為就是個(gè)長(zhǎng)長(zhǎng)的字符串),瀏覽器客戶端拿到這個(gè)token。

3.后續(xù)每次請(qǐng)求中,瀏覽器會(huì)把token作為http header發(fā)送給服務(wù)器,服務(wù)器驗(yàn)證簽名是否有效,如果有效那么認(rèn)證就成功,可以返回客戶端需要的數(shù)據(jù)。

4.一旦用戶退出登錄,只需要客戶端銷毀token即可,服務(wù)器端不需要任何操作。

B)token認(rèn)證方式的特點(diǎn)

這種方式的特點(diǎn)就是客戶端的token中自己保留有大量信息,服務(wù)器沒(méi)有存儲(chǔ)這些信息,而只負(fù)責(zé)驗(yàn)證,不必進(jìn)行數(shù)據(jù)庫(kù)查詢,執(zhí)行效率大大提高。

三. JWT

A)JWT介紹

1.JWT是json web token縮寫。它將用戶信息加密到token里,服務(wù)器不保存任何用戶信息。服務(wù)器通過(guò)使用保存的密鑰驗(yàn)證token的正確性,只要正確即通過(guò)驗(yàn)證。

2.優(yōu)點(diǎn)是在分布式系統(tǒng)中,很好地解決了單點(diǎn)登錄問(wèn)題,很容易解決了session共享的問(wèn)題。jwt長(zhǎng)度較小,且可以使用URL傳輸(URLsafe)。不想cookies只能在web環(huán)境起作用。 JWT可以同時(shí)使用在web環(huán)境和RESTfull的接口。

缺點(diǎn)是無(wú)法作廢已頒布的令牌/不易應(yīng)對(duì)數(shù)據(jù)過(guò)期。

B)JWT組成

JWT包含三個(gè)部分: Header頭部,Payload負(fù)載和Signature簽名。由三部分生成token,三部分之間用“.”號(hào)做分割。

列如 :

eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c

1.Header

在Header中通常包含了兩部分:type:代表token的類型,這里使用的是JWT類型。 alg:使用的Hash算法,例如HMAC SHA256或RSA.

{
“alg”: “HS256”,
“typ”: “JWT”
}

這會(huì)被經(jīng)過(guò)base64Url編碼形成第一部分

2.Payload

token的第二個(gè)部分是荷載信息,它包含一些聲明Claim(實(shí)體的描述,通常是一個(gè)User信息,還包括一些其他的元數(shù)據(jù))

聲明分三類:

1)Reserved Claims,這是一套預(yù)定義的聲明,并不是必須的,這是一套易于使用、操作性強(qiáng)的聲明。包括:iss(issuer)、exp(expirationtime)、sub(subject)、aud(audience)等

2)Plubic Claims,

3)Private Claims,交換信息的雙方自定義的聲明

{
“sub”: “1234567890”,
“name”: “John Doe”,
“admin”: true
}

同樣經(jīng)過(guò)Base64Url編碼后形成第二部分

3.signature

使用header中指定的算法將編碼后的header、編碼后的payload、一個(gè)secret進(jìn)行加密。

例如使用的是HMAC SHA256算法,大致流程類似于: HMACSHA256( base64UrlEncode(header) + “.” + base64UrlEncode(payload), secret)

這個(gè)signature字段被用來(lái)確認(rèn)JWT信息的發(fā)送者是誰(shuí),并保證信息沒(méi)有被修改

C)為什么要使用JWT

相比XML格式,JSON更加簡(jiǎn)潔,編碼之后更小,這使得JWT比SAML更加簡(jiǎn)潔,更加適合在HTML和HTTP環(huán)境中傳遞。

在安全性方面,SWT只能夠使用HMAC算法和共享的對(duì)稱秘鑰進(jìn)行簽名,而JWT和SAML

token則可以使用X.509認(rèn)證的公私秘鑰對(duì)進(jìn)行簽名。與簡(jiǎn)單的JSON相比,XML和XML數(shù)字簽名會(huì)引入復(fù)雜的安全漏洞。

因?yàn)镴SON可以直接映射為對(duì)象,在大多數(shù)編程語(yǔ)言中都提供了JSON解析器,而XML則沒(méi)有這么自然的文檔-對(duì)象映射關(guān)系,這就使得使用JWT比SAML更方便

java json web token工具類

D)JWT的Maven引入

<dependency>
    <groupId>io.jsonwebtoken</groupId>
    <artifactId>jjwt</artifactId>
    <version>0.9.0</version>
</dependency>

到此,相信大家對(duì)“JWT與cookie和token的區(qū)別有哪些”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI