日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JSON Web Token (JWT)生成Token及解密实战

發(fā)布時間:2023/12/3 javascript 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JSON Web Token (JWT)生成Token及解密实战 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

轉(zhuǎn)載自?JSON Web Token (JWT)生成Token及解密實戰(zhàn)

昨天講解了JWT的介紹、應(yīng)用場景、優(yōu)點及注意事項等,今天來個JWT具體的使用實踐吧。

從JWT官網(wǎng)支持的類庫來看,jjwt是Java支持的算法中最全的,推薦使用,網(wǎng)址如下。

https://github.com/jwtk/jjwt

下面來看看如何使用jjwt來實現(xiàn)JWT token的生成與解密,主要用到sha512算法來演示。

1、導(dǎo)入jjwt的maven包。

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

注意:JJWT依賴Jackson 2.x,低版本將報錯。

2、建立一個JWTTest測試類。

3、創(chuàng)建密鑰;

這里使用sha512算法,所以需要一個密鑰。

Key KEY = new SecretKeySpec("javastack".getBytes(),SignatureAlgorithm.HS512.getJcaName());

這樣就生成了一個固定的密鑰:javastack

4、生成JWT token。

核心代碼如下:

Map<String, Object> stringObjectMap = new HashMap<>(); stringObjectMap.put("type", "1"); String payload = "{\"user_id\":\"1341137\", \"expire_time\":\"2018-01-01 0:00:00\"}"; String compactJws = Jwts.builder().setHeader(stringObjectMap) .setPayload(payload).signWith(SignatureAlgorithm.HS512, KEY).compact(); System.out.println("jwt key:" + new String(KEY.getEncoded())); System.out.println("jwt payload:" + payload); System.out.println("jwt encoded:" + compactJws);

注意:header可以不用設(shè)置,claims不能和payload同時設(shè)置。

輸出結(jié)果:

jwt key:javastack jwt payload:{"user_id":"1341137", "expire_time":"2018-01-01 0:00:00"} jwt encoded:eyJ0eXBlIjoiMSIsImFsZyI6IkhTNTEyIn0.eyJ1c2VyX2lkIjoiMTM0MTEzNyIsICJleHBpcmVfdGltZSI6IjIwMTgtMDEtMDEgMDowMDowMCJ9.cnyXRnwczgNcNYqV6TUY2MaMfk6vujsZltC8Q51l40dwYJg516oZcV4VDKOypPT8fD7AE63PIhfdm2ALVrfv5A

5、解密JWT token內(nèi)容。

核心代碼如下:

Jws<Claims> claimsJws = Jwts.parser().setSigningKey(KEY).parseClaimsJws(compactJws); JwsHeader header = claimsJws.getHeader(); Claims body = claimsJws.getBody(); System.out.println("jwt header:" + header); System.out.println("jwt body:" + body); System.out.println("jwt body user-id:" + body.get("user_id", String.class));

輸出結(jié)果:

jwt header:{type=1, alg=HS512} jwt body:{user_id=1341137, expire_time=2018-01-01 0:00:00} jwt body user-id:1341137

再用密文去JWT官網(wǎng)的調(diào)試器解密一下,看是否成功。

解密成功,其他算法使用邏輯一樣,這樣我們可以使用JWT來實現(xiàn)不同服務(wù)之間數(shù)據(jù)的安全傳遞。


總結(jié)

以上是生活随笔為你收集整理的JSON Web Token (JWT)生成Token及解密实战的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。