生成和解析JWT令牌【工具类】

首先引入在Maven工程中的pom.xml文件中引入jjwt依赖。
<dependency>
    <groupId>io.jsonwebtoken</groupId>
    <artifactId>jjwt</artifactI
    <version>0.9.1</version>
</dependency>
创建工具类--这里使用硬编码格式:
import io.jsonwebtoken.Claims;
import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import java.util.Date;
import java.util.Map;
@Slf4j
public class JwtUtils {
    private static  String signKey = "签名密钥";
    private static  Long expire = 有效时间;
    /**
     * 生成jwt令牌
     */
    public static String GenPaceJWT(Map<String, Object> claim){
        String jwt = Jwts.builder()                                                         // 构建jwt令牌
                .signWith(SignatureAlgorithm.HS256, signKey)                                // 设置数字签名的算法及密钥
                .setClaims(claim)                                                           // 设置自定义的数据(载荷)
                .setExpiration(new Date(System.currentTimeMillis() + expire))               // 设置令牌有效时间,new date表示当前时间,传递当前时间的毫秒值
                .compact();                                                                 // 生成令牌
        log.info("生成的jwt令牌是:{}",jwt);
        return jwt;
    }
    /**
     * 解析jwt令牌
     */
    public static Claims ParseJWT(){
        Claims claims = Jwts.parser()                                                   // 解析令牌
                .setSigningKey(signKey)                                                 // 指定签名的密钥,要和生成是的保持一致
                .parseClaimsJws("eyJhbGciOiJIUzI1NiJ9.eyJuYW1lIjoiVG9tIiwiaWQiOjEsImV4cCI6MTcwNjY3NzcwNX0.Gn7PDHE04v08WF8MQckU3C8hGa55bpsx0Ri1NjT1Tq0")
                .getBody();
        log.info("解析后的结果为:{}",claims);
        return claims;
    }
}

  • 9
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值