maven中添加jjwt
<!-- jjwt-->
<dependency>
<groupId>io.jsonwebtoken</groupId>
<artifactId>jjwt</artifactId>
<version>0.9.1</version>
</dependency>
jwt工具類, 必須要添加@Component注解(類中私有的值是通過從yml文件中獲取的,如果不加@Value會為null),單純只測試jwt改為常量就好。
package com.dome.provider.config.security.jwt; import io.jsonwebtoken.Claims; import io.jsonwebtoken.Jwts; import io.jsonwebtoken.SignatureAlgorithm; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; import java.util.Date; @Component public class JwtUtils { @Value("${jwt.secret}") private String secret; @Value("${jwt.expiration}") private Long expiration; /** * 創建token * @param username 用戶名 * @return */ public String generateToken(String username) { return Jwts.builder() .signWith(SignatureAlgorithm.HS256, secret) .setSubject(username) .setIssuedAt(new Date()) .setExpiration(new Date(System.currentTimeMillis() + expiration * 1000)) .compact(); } /** * 從token中獲取用戶名 * @param token * @return */ public String getUserNameFromToken(String token){ return getTokenBody(token).getSubject(); } /** * 是否已過期 * @param token * @return */ public boolean isExpiration(String token){ return getTokenBody(token).getExpiration().before(new Date()); } /** * 獲取token中的信息 * @param token * @return */ private Claims getTokenBody(String token){ return Jwts.parser() .setSigningKey(secret) .parseClaimsJws(token) .getBody(); } }
