生成和解析JWT令牌的工具类

使用JWT令牌需导入依赖
<dependency>
    <groupId>io.jsonwebtoken</groupId>
    <artifactId>jjwt</artifactId>
    <version>0.9.1</version>
</dependency>
工具类

public class JwtUtils {
    private static String singKey = "leiguanfa";//设置密钥
    private static Long expire = 3600*1000L;//设置过期时间为一小时以后

    public static String generateJwt(Map<String,Object> claims){
        String jwt = Jwts.builder()
                .signWith(SignatureAlgorithm.HS256, singKey)//签名算法:第二个字符串不能过长或过短
                .setClaims(claims)//设置自定义内容
                .setExpiration(new Date(System.currentTimeMillis() + expire))//设置有效期
                .compact();//生成令牌
        return jwt;
    }
    public static Claims parseJwt(String jwt){
        Claims str = Jwts.parser()
                .setSigningKey(singKey)
                .parseClaimsJws(jwt)//解析令牌
                .getBody();
        return str;
    }

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的JWT工具类示例代码: ``` import io.jsonwebtoken.Claims; import io.jsonwebtoken.Jwts; import io.jsonwebtoken.SignatureAlgorithm; import java.util.Date; public class JWTUtils { private static final String SECRET_KEY = "mySecretKey"; public static String generateToken(String subject, long ttlMillis) { long nowMillis = System.currentTimeMillis(); Date now = new Date(nowMillis); return Jwts.builder() .setSubject(subject) .setIssuedAt(now) .setExpiration(new Date(nowMillis + ttlMillis)) .signWith(SignatureAlgorithm.HS256, SECRET_KEY) .compact(); } public static Claims parseToken(String token) { return Jwts.parser() .setSigningKey(SECRET_KEY) .parseClaimsJws(token) .getBody(); } public static String getSubject(String token) { Claims claims = parseToken(token); return claims.getSubject(); } public static long getRemainingTime(String token) { Claims claims = parseToken(token); Date expiration = claims.getExpiration(); return expiration.getTime() - System.currentTimeMillis(); } } ``` 这个工具类使用了Java JWT库来处理JWT。其中,`generateToken`方法接受一个主题和一个过期时间(以毫秒为单位),并返回一个JWT令牌字符串。`parseToken`方法接受一个JWT令牌字符串,并返回一个包含JWT声明的`Claims`对象。`getSubject`方法接受一个JWT令牌字符串,并返回JWT声明中的主题。`getRemainingTime`方法接受一个JWT令牌字符串,并返回JWT令牌剩余有效期的毫秒数。 请注意,在实际应用中,应该使用更复杂的密钥和签名算法,以提高JWT的安全性。此外,还应该考虑使用HTTPS来保护JWT在传输过程中的安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值