笔记:创建JWT工具类实现token验证、获取、创建

​
package com.ruoyi.jy.util;

import com.auth0.jwt.JWT;
import com.auth0.jwt.JWTCreator;
import com.auth0.jwt.algorithms.Algorithm;
import com.auth0.jwt.interfaces.Claim;
import com.auth0.jwt.interfaces.DecodedJWT;

import java.io.UnsupportedEncodingException;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;


public class JWTUtils {
    /**
     * 生成Token
     */
    private static final String  SING="JINWANDALAOHU";

    public static String createToken(Map<String,String> map) throws UnsupportedEncodingException {
        Calendar instance = Calendar.getInstance();
        instance.add(Calendar.DATE,7);
        //创建JWT builder
        JWTCreator.Builder builder= JWT.create();
        //payload
        map.forEach((k,v)->{
            builder.withClaim(k,v);
        });
        String   token = builder.withExpiresAt(instance.getTime())
                .sign(Algorithm.HMAC256(SING));
    return token;
    }

    /**
     * 验证token 合法性
     */
    public static  DecodedJWT verify(String token) throws UnsupportedEncodingException {
       return JWT.require(Algorithm.HMAC256(SING)).build().verify(token);
    }

    /**
     * 获取token信息
     * @param token
     * @return
     */
    public static Map<String,String> getTokenInfo(String token) throws UnsupportedEncodingException {
        DecodedJWT verify = JWT.require(Algorithm.HMAC256(SING)).build().verify(token);
        SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String exp= sdf1.format(verify.getExpiresAt());
        Map<String, Claim> claims = verify.getClaims();
        Map<String,String> m=new HashMap<>();
        claims.forEach((k,v)->{
            m.put(k,v.asString());
        });
        m.put("exp",exp);
        return m;
    }

    public static void main(String[] args) throws UnsupportedEncodingException {
        String sing="JINWANDALAOHU";
        Calendar instance = Calendar.getInstance();
        instance.add(Calendar.SECOND,20);
        String token = JWT.create()
                .withClaim("username", "xxx")
                .withClaim("userid", "1")
                .withExpiresAt(instance.getTime())
                .sign(Algorithm.HMAC256(sing));

        System.out.println(token);

        System.out.println("---------------------开始解析------------");
        DecodedJWT verify = JWT.require(Algorithm.HMAC256(SING)).build().verify(token);
        SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String exp= sdf1.format(verify.getExpiresAt());
        Map<String, Claim> claims = verify.getClaims();
        Map<String,String> m=new HashMap<>();
        claims.forEach((k,v)->{
            m.put(k,v.asString());
            m.remove("exp");
        });
        m.put("exp",exp);
        m.forEach((k,v)->{
            System.out.println("k"+k+"-----"+v);
        });

        System.out.println("verify"+verify.getClaims());
        System.out.println(verify.getClaim("username").asString());
        System.out.println(verify.getClaim("userid").asLong());
        System.out.println(verify.getExpiresAt());


    }
}

​

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值