yb课堂之登陆校验Json Web Token实战之封装通用方法 《九》

Posted chenyanbin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了yb课堂之登陆校验Json Web Token实战之封装通用方法 《九》相关的知识,希望对你有一定的参考价值。

引入相关依赖并开发JWT工具类,开发生产token和校验token的方法

加入相关依赖

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

封装生产token方法

封装校验token方法

JWTUtils.java

package net.ybclass.online_ybclass.utils;

import io.jsonwebtoken.Claims;
import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;
import net.ybclass.online_ybclass.domain.User;

import java.util.Date;

/**
 * JWT工具类
 * 注意点:
 * 1、生成的token,是可以通过base64进行解密出铭文信息
 * 2、base64进行解密出明文信息,修改再进行编码,则会解密失败
 * 3、无法作废已颁布的token,除非改密钥
 */
public class JWTUtils {
    /**
     * 过期时间,一周
     */
    static final long EXPIRE = 60000 * 60 * 24 * 7;
    /**
     * 加密密钥
     */
    private static final String SECRET = "ybclass.net168";
    /**
     * 令牌前缀
     */
    private static final String TOKEN_PREFIX = "ybclass";
    /**
     * 主题
     */
    private static final String SUBJECT = "ybclass";

    /**
     * 根据用户信息,生成令牌
     *
     * @param user
     * @return
     */
    public static String geneJsonWebToken(User user) {
        String token = Jwts.builder().setSubject(SUBJECT)
                .claim("head_img", user.getHeadImg())
                .claim("id", user.getId())
                .claim("name", user.getName())
                .setIssuedAt(new Date()) //令牌颁布时间
                .setExpiration(new Date(System.currentTimeMillis() + EXPIRE)) //过期时间
                .signWith(SignatureAlgorithm.HS256, SECRET) //加密方式
                .compact();
        token = TOKEN_PREFIX + token;
        return token;
    }

    /**
     * 校验token方法
     *
     * @param token
     * @return
     */
    public static Claims checkJWT(String token) {
        try {
            final Claims claims = Jwts.parser()
                    .setSigningKey(SECRET)
                    .parseClaimsJws(token.replace(TOKEN_PREFIX, ""))
                    .getBody();
            return claims;
        } catch (Exception e) {
            return null;
        }
    }
}

以上是关于yb课堂之登陆校验Json Web Token实战之封装通用方法 《九》的主要内容,如果未能解决你的问题,请参考以下文章

yb课堂 实战之路由拦截和订单模块 《四十二》

yb课堂之个人信息接口开发 《十三》

yb课堂之用户注册登陆模块《六》

yb课堂实战之播放记录表设计和模块开发 《十五》

java WT -- JSON WEB TOKEN 加密/校验工具类

JSON Web Token(JWT)