91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java-jwt生成與校驗的示例分析

發布時間:2021-06-24 14:00:00 來源:億速云 閱讀:306 作者:小新 欄目:編程語言

小編給大家分享一下java-jwt生成與校驗的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

什么是 JWT

這里是jwt 官方地址,想了解更多的可以在這里查看。

jwt 全稱是JSON Web Token,從全稱就可以看出 jwt 多用于認證方面的。這個東西定義了一種簡潔的,自包含的,安全的方法用于通信雙方以 json 對象的形式傳遞信息。其中簡潔,安全,傳遞信息和 web 系統非常契合。

jwt 實際上就是一個字符串,由以下三個部分構成(通過.分隔):

  • Header 頭部

  • Payload 負載

  • Signature 簽名

因此一個 jwt 字符串都是如下的形式:

Header.Payload.Signature

Header

header 大多數情況下是只包含兩個屬性的 json 字符串,token 的類型(“JWT”)和用到的算法(比如 HS256,RS256,ES256 等)如下:

{
"alg": "HS256",
"typ": "JWT"
}

然后用 Base64 將其編碼就等到了 jwt 的第一部分

Payload
payload 顧名思義用于攜帶數據的,這里的數據有三種類型:

  • Registered claims:一組預定義的聲明,寫在 jwt 標準中,所有對其的實現都要準守。但不是強制要求攜帶。有以下幾個字段:iss(簽發者),iat(創建時間),exp(過期時間),aud(簽發者),sub(面向的用戶)

  • public claims:隨意定義,通常存放用戶 id,用戶類別等非銘感信息

這些數據也是 json 的形式,用 Base64 編碼后就得到了 JWT 的第二個部分。

Signature

簽名就是通過設定的秘鑰和簽名算法來對 header 和 payload 進行簽名得到一個簽名字符串,將這三個字符串組合起來就是 JWT 了。

java 中使用

通過java-jwt來實現,首先引入依賴:

<dependency>
<!-- 截止當前最新版本為3.7 -->
<groupId>com.auth0</groupId>
<artifactId>java-jwt</artifactId>
<version>3.7.0</version>
</dependency>

簽名

使用 HMC256,代碼入下:

private static final Algorithm ALGORITHM= Algorithm.HMAC256("security");
public static String encode() {
//通過秘鑰生成一個算法
String token = JWT.create()
//設置簽發者
.withIssuer("test")
//設置過期時間為一個小時
.withExpiresAt(new Date(System.currentTimeMillis()+60*60*1000))
//設置用戶信息
.withClaim("name","小明")
.withClaim("age",20)
.sign(ALGORITHM);
return token;
}

驗證

驗證代碼如下:

//校驗類
private static final JWTVerifier JWT_VERIFIER= JWT.require(ALGORITHM).withIssuer("test").build();
public static void decode(String token) {
DecodedJWT decodedJWT = JWT_VERIFIER.verify(token);
//如果校驗失敗會拋出異常
//payload可從decodeJWT中獲取
}

以上是“java-jwt生成與校驗的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

罗江县| 南昌市| 孟津县| 潜山县| 肥西县| 太谷县| 阳江市| 缙云县| 宁强县| 凤山市| 广西| 东宁县| 淅川县| 怀集县| 大荔县| 左云县| 上虞市| 杨浦区| 台前县| 余江县| 安溪县| 平定县| 绥江县| 蒲江县| 广昌县| 积石山| 新巴尔虎左旗| 枣庄市| 齐齐哈尔市| 垣曲县| 中方县| 开封县| 柞水县| 安庆市| 垫江县| 淄博市| 福泉市| 科技| 同江市| 龙口市| 永新县|