jwt工具类
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(); } }