栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

JWT的总结与使用

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

JWT的总结与使用

1. JWT的结构

jwt由三段组成,通过 . 来连接,表现为:xxx.yyy.zzz

xxx:表示标头

yyy:表示有效载荷

zzz:签名

标头Header:

{
    "alg":"HS256", # 加密算法
    "typ":"JWT" # 类型
}

有效载荷Payload:

用来存储一些常用数据,例如用户id等等信息。例如:

{
    "userId":"1", # 用户id
    "userName":"" # 用户名称
    ......
}

签名:使用Header和Payload进行Base64编码,两个编码加起来,再加上一个随机盐。随机盐对外不可见,三个加起来后,进行HS256加密,形成签名串。

2. Java中使用JWT

添加对应的jar包

        
        
            com.auth0
            java-jwt
            3.4.0
        

新建一个测试类测试

import com.auth0.jwt.JWT;
import com.auth0.jwt.JWTVerifier;
import com.auth0.jwt.algorithms.Algorithm;
import com.auth0.jwt.interfaces.DecodedJWT;
import org.junit.Test;

import java.util.Calendar;


public class JwtTest {

    private static final String sign = "ksjncankjanckjd";

    //令牌的获取
    @Test
    public void create() {
        //配置jwt有效时间
        Calendar instance = Calendar.getInstance();
        instance.add(Calendar.SECOND, 60);
        String token = JWT.create()
                .withClaim("userId", 1)
                .withClaim("userName", "张三")
                .withClaim("age", 20)
                .withExpiresAt(instance.getTime())
                .sign(Algorithm.HMAC256(sign));
        System.out.println(token);
    }

    //验证并获取token的信息
    @Test
    public void verifier() {
        JWTVerifier jwtVerifier = JWT.require(Algorithm.HMAC256(sign)).build();
        String sign = "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VyTmFtZSI6IuW8oOS4iSIsImV4cCI6MTY1MTA2ODg0MSwidXNlcklkIjoxLCJhZ2UiOjIwfQ.7Z3b5HJi9JolL_vSvgSOvySV-ivxLiBAdYL-3eK8mUs";
        DecodedJWT verify = jwtVerifier.verify(sign);
        System.out.println(verify.getClaim("userId").asInt());
        System.out.println(verify.getClaim("userName").asString());
        System.out.println(verify.getClaim("age").asInt());
    }
}
3. 项目中使用JWT

创建工具类JwtUtil

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

import java.util.Calendar;
import java.util.Map;


public class JwtUtil {
    //随机盐
    private static final String SIGN = "sdlnjcslkdlkvm";
    //jwt过期时间
    private static final int VALIDITY = 7;

    
    public static String getToken(Map map) {
        //配置jwt有效时间
        Calendar instance = Calendar.getInstance();
        instance.add(Calendar.DATE, VALIDITY);
        //创建jwt的Builder
        JWTCreator.Builder builder = JWT.create();
        //payload
        map.forEach(builder::withClaim);
        //设置过期时间与签名
        String token = builder.withExpiresAt(instance.getTime()).sign(Algorithm.HMAC256(SIGN));
        System.out.println(token);
        return token;
    }

    
    public static DecodedJWT verify(String token) {
        return JWT.require(Algorithm.HMAC256(SIGN)).build().verify(token);
    }
}

使用的话,一般是登录接口校验成功返回token,其他接口请求携带token校验通过后进入业务逻辑,并且在逻辑中可以直接通过封装的工具类,可以获取到jwt中携带的信息值参与业务

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/846166.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号