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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

系统微服务签发token

發(fā)布時間:2023/12/3 windows 52 豆豆
生活随笔 收集整理的這篇文章主要介紹了 系统微服务签发token 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

一、JwtUtil 工具類

package com.changgou.system.utils;/*** @author :lijunxuan* @date :Created in 2019/7/11 17:14* @description :* @version: 1.0*/import io.jsonwebtoken.JwtBuilder; import io.jsonwebtoken.Jwts; import io.jsonwebtoken.SignatureAlgorithm;import javax.crypto.SecretKey; import javax.crypto.spec.SecretKeySpec; import java.util.Base64; import java.util.Date;/*** JWT工具類*/ public class JwtUtil {//有效期為public static final Long JWT_TTL = 3600000L;// 60 * 60 *1000 一個小時//設置秘鑰明文public static final String JWT_KEY = "william";/*** 創(chuàng)建token* @param id* @param subject* @param ttlMillis* @return*/public static String createJWT(String id, String subject, Long ttlMillis) {//定義jwt簽名的算法SignatureAlgorithm signatureAlgorithm = SignatureAlgorithm.HS256;//當前時間long nowMillis = System.currentTimeMillis();//將當前時間轉換日期類型Date now = new Date(nowMillis);//將當前時間+超時時間if(ttlMillis==null){ttlMillis=JwtUtil.JWT_TTL;}long expMillis = nowMillis + ttlMillis;//將時間定義為date類型Date expDate = new Date(expMillis);//獲取簽名時候使用的密鑰SecretKey secretKey = generalKey();JwtBuilder builder = Jwts.builder().setId(id) //唯一的ID.setSubject(subject) // 主題 可以是JSON數(shù)據(jù).setIssuer("admin") // 簽發(fā)者.setIssuedAt(now) // 簽發(fā)時間.signWith(signatureAlgorithm, secretKey) //使用HS256對稱加密算法簽名, 第二個參數(shù)為秘鑰.setExpiration(expDate);// 設置過期時間return builder.compact();}/*** 生成加密后的秘鑰 secretKey* @return*/public static SecretKey generalKey() {byte[] encodedKey = Base64.getDecoder().decode(JwtUtil.JWT_KEY);SecretKey key = new SecretKeySpec(encodedKey, 0, encodedKey.length, "AES");return key;} }

二、修改AdminController的login方法, 用戶登錄成功 則 簽發(fā)TOKEN

/*** 管理員登錄* @param admin* @return*/@PostMapping(value = "/login")public Result login(@RequestBody Admin admin){boolean isLogin =adminService.isLogin(admin);HashMap<String, String> ResultMap = new HashMap<>();if (isLogin){//生成JWt令牌String token = JwtUtil.createJWT(UUID.randomUUID().toString(), admin.getLoginName(), null);ResultMap.put("loginName",admin.getLoginName());ResultMap.put("token",token);return new Result(true,StatusCode.OK,"登錄成功",ResultMap);}else {return new Result(false,StatusCode.ERROR,"登錄失敗");}}

三、測試結果

總結

以上是生活随笔為你收集整理的系统微服务签发token的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。