目录
- 1. 导入JWT相关依赖
- 2. JWT生成token
- 3. JWT解析token
- 4. 测试结果
- 5. JWT加密、解密工具类
1. 导入JWT相关依赖
<!-- jwt认证模块--><dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt-api</artifactId><version>0.10.2</version></dependency>
<!-- jwt api impl实现--><dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt-impl</artifactId><version>0.10.2</version></dependency>
<!-- jwt json--><dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt-jackson</artifactId><version>0.10.2</version></dependency>
2. JWT生成token
/*** 获取JWT令牌* @return*/public static String getToken(String key){Map headers = new HashMap();//设置签名算法headers.put("alg", "HS256");//设置令牌类型headers.put("typ", "JWT");Map<String, Object> claims = new HashMap<>();//设置令牌主题claims.put("sub", "1234567890");//设置令牌其他信息claims.put("name", "John Doe");claims.put("admin", true);//生成令牌String jwt = Jwts.builder()//设置头信息.setHeaderParams(headers)//设置负载信息.setClaims(claims)//使用HS256算法和密钥对JWT进行签名.signWith(SignatureAlgorithm.HS256,key)//将之前设置的头部信息、负载信息和签名信息组合成一个完整的JWT,并以字符串形式返回.compact();System.out.println(jwt);return jwt;}
3. JWT解析token
/*** 解析JWT令牌* @param token* @param key*/public static void parseToken(String token,String key){try{System.out.println("开始解析令牌...");Claims claims = Jwts.parser()//创建一个解析器.setSigningKey(key)//设置验证签名的密钥.parseClaimsJws(token)//传入需要进行解析的token并解析.getBody();//从Jws<Claims>对象中获取负载信息System.out.println(claims);}catch (Exception e){e.printStackTrace();}}
4. 测试结果
public static void main(String[] args) {String key = "3f2e1d4c5b6a79808f7e6d5c4b3a29181716151413121110";String token = getToken(key);parseToken(token,key);}
输出结果:
5. JWT加密、解密工具类
/*** 提供Jwt工具类* 提供Token生成和验证方法* @author Huan*/
@Component //托管spring容器
public class JwtUtil {// 密钥private static final String key = "3f2e1d4c5b6a79808f7e6d5c4b3a29181716151413121110";/*** 生成JWT令牌* @param payload* @return*/public String getToken(Map payload){//设置头部信息Map headers = new HashMap();//设置签名算法headers.put("alg", "HS256");//设置令牌类型headers.put("typ", "JWT");//生成令牌String jwt = Jwts.builder()//设置头信息.setHeaderParams(headers)//设置负载信息.setClaims(payload)//使用HS256算法和密钥对JWT进行签名.signWith(SignatureAlgorithm.HS256,key)//将之前设置的头部信息、负载信息和签名信息组合成一个完整的JWT,并以字符串形式返回.compact();System.out.println(jwt);return jwt;}/*** 解析JWT令牌* @param token* @return*/public Claims parseToken(String token){try{System.out.println("开始解析令牌...");Claims claims = Jwts.parser()//创建一个解析器.setSigningKey(key)//设置验证签名的密钥.parseClaimsJws(token)//传入需要进行解析的token并解析.getBody();//从Jws<Claims>对象中获取负载信息System.out.println(claims);return claims;}catch (Exception e){e.printStackTrace();}return null;}
}
链接:
JWT官方地址: https://jwt.io/
JWT官方文档: https://github.com/jwtk/jjwt
JWT官方文档快速开始: https://github.com/jwtk/jjwt?tab=readme-ov-file#quickstart