Jwt工具类

Posted lovoo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Jwt工具类相关的知识,希望对你有一定的参考价值。

1、JWT简介

JWT:Json Web Token,是基于Json的一个公开规范,这个规范允许我们使用JWT在用户和服务器之间传递安全可靠的信息,他的两大使用场景是:认证和数据交换

使用起来就是,由服务端根据规范生成一个令牌(token),并且发放给客户端。此时客户端请求服务端的时候就可以携带者令牌,以令牌来证明自己的身份信息。

作用:类似session保持登录状态 的办法,通过token来代表用户身份。

2、JWT生成

3、工具类源码

@Getter
@Setter
@ConfigurationProperties("jwt.config")
public class JwtUtils {
    //签名私钥
    private String key;
    //签名的失效时间
    private Long ttl;

    public static void main(String[] args) {
        long now = System.currentTimeMillis();//当前毫秒
        long exp = now + 3600000;
        //2.创建jwtBuilder
        JwtBuilder jwtBuilder = Jwts.builder().setId("88").setSubject("加密")
                .setIssuedAt(new Date())
                .signWith(SignatureAlgorithm.HS256, "kkkk")
                .claim("companyId", 1)
                .claim("name", "tom")
                ;
        //3.根据map设置claims
//        for (Map.Entry<String, Object> entry : map.entrySet()) {
//            jwtBuilder.claim(entry.getKey(), entry.getValue());
//        }
//        jwtBuilder.setExpiration(new Date(exp));
        //4.创建token
        String token = jwtBuilder.compact();
        System.out.println(token);
    }

    /**
     * 设置认证token
     * id:登录用户id
     * subject:登录用户名
     */
    public String createJwt(String id, String name, Map<String, Object> map) {
        //1.设置失效时间
        long now = System.currentTimeMillis();//当前毫秒
        long exp = now + ttl;
        //2.创建jwtBuilder
        JwtBuilder jwtBuilder = Jwts.builder().setId(id).setSubject(name)
                .setIssuedAt(new Date())
                .signWith(SignatureAlgorithm.HS256, key);
        //3.根据map设置claims
        for (Map.Entry<String, Object> entry : map.entrySet()) {
            jwtBuilder.claim(entry.getKey(), entry.getValue());
        }
        jwtBuilder.setExpiration(new Date(exp));
        //4.创建token
        String token = jwtBuilder.compact();
        return token;
    }


    /**
     * 解析token字符串获取clamis
     */
    public Claims parseJwt(String token) {
        Claims claims = Jwts.parser().setSigningKey(key).parseClaimsJws(token).getBody();
        return claims;
    }

}

配置application.properties

jwt.config.key=saas-ihrm
jwt.config.ttl=3600000

以上是关于Jwt工具类的主要内容,如果未能解决你的问题,请参考以下文章

内嵌jwt工具类)

Jwt工具类

JWT 工具类

SpringBoot+JWT+Redis实现单用户登录

JWT 加密工具类

JWT 加密工具类