JWT的Java使用(10分钟上手)

关于jwt的背景概念什么的网上很多,此处不谈。
楼主的应用背景是一个老网站需要调用新后台的报表,但是又得验证身份,故此用此技术。此技术大多用于单点登录:在这里插入图片描述
上图很明显的展示了流程,直接上代码:
引入核心包:

<dependency>
            <groupId>com.auth0</groupId>
            <artifactId>java-jwt</artifactId>
            <version>3.8.2</version>
</dependency>

 <dependency>
            <groupId>io.jsonwebtoken</groupId>
            <artifactId>jjwt</artifactId>
            <version>0.6.0</version>
 </dependency>

主流程:

public static void main(String[] args) throws Exception {
        JwtUtil util=	new JwtUtil();
        //创建一个jwt
        String ab=util.createJWT("jwt", "{id:1,name:张三}", 30000);

		//接收  
       // 这里写一个循环 看看时间周期  一旦过了时间,就会产生异常
        for(int i=0;i<=5;i++){
            Claims c=util.parseJWT(ab);
            System.out.println("第"+i+"次");
            System.out.println(c.getId());//jwt
            System.out.println(c.getIssuedAt());
            System.out.println(c.getSubject());
            System.out.println(c.getIssuer());
            System.out.println(c.get("uid", String.class));
            Thread.sleep(6000);
        }
       
    } 

创建jwt

public String createJWT(String id, String subject, long ttlMillis) throws Exception {
        SignatureAlgorithm signatureAlgorithm = SignatureAlgorithm.HS256; //指定签名的时候使用的签名算法
        long nowMillis = System.currentTimeMillis();//生成JWT的时间
        Date now = new Date(nowMillis);
        Map<String,Object> claims = new HashMap<String,Object>();//payload的私有声明 
        claims.put("uid", "sdasdas...");
        claims.put("user_name", "admin");
        claims.put("nick_name","1q2w23e");
        SecretKey key = generalKey();//秘钥    接收方需要这个解析  有多重要就不必多说了
        JwtBuilder builder = Jwts.builder() //这里其实就是new一个JwtBuilder,设置jwt的body
                .setClaims(claims) 		
                .setId(id)					//设置jti(JWT ID):是JWT的唯一标识,主要用来作为一次性token
                .setIssuedAt(now)			//iat: jwt的签发时间
                .setSubject(subject)		//sub(Subject):代表这个JWT的主体,这个是一个json格式的字符串
                .signWith(signatureAlgorithm, key);//设置签名使用的签名算法和签名使用的秘钥
        if (ttlMillis >= 0) {
            long expMillis = nowMillis + ttlMillis;
            Date exp = new Date(expMillis);
            builder.setExpiration(exp);		//设置过期时间
        }
        return builder.compact();			//就开始压缩为xxxx.xxxx.xxxx这样的jwt,然后接收方解压       
    }

解析jwt

 public Claims parseJWT(String jwt) throws Exception{
        SecretKey key = generalKey();  //签名秘钥,和生成的签名的秘钥一模一样
        Claims claims = Jwts.parser()  //得到DefaultJwtParser
                .setSigningKey(key)         //设置签名的秘钥
                .parseClaimsJws(jwt).getBody();//设置需要解析的jwt
        return claims;
    }    

密钥生成方法:

 public SecretKey generalKey(){
        String stringKey = "123asd1";
        byte[] encodedKey = Base64.decodeBase64(stringKey);
        SecretKey key = new SecretKeySpec(encodedKey, 0, encodedKey.length, "AES");
        return key;
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值