首页 > 其他分享 >JWT 和MD5加密工具类的封装是使用

JWT 和MD5加密工具类的封装是使用

时间:2023-05-21 21:34:00浏览次数:52  
标签:return String userId JWT token static 封装 public MD5

jwt

  1 package com.atguigu.common.jwt;
  2 
  3 import io.jsonwebtoken.*;
  4 import org.springframework.util.StringUtils;
  5 
  6 import java.util.Date;
  7 
  8 //jwt工具类
  9 public class JwtHelper {
 10 
 11     private static long tokenExpiration = 60 * 60 * 24;
 12     private static String tokenSignKey = "123456";
 13 
 14     //根据用户id和用户名称生成token字符串
 15     public static String createToken(Long userId, String username) {
 16         String token = Jwts.builder()
 17                 //分类
 18                 .setSubject("AUTH-USER")
 19 
 20                 //设置token有效时长
 21                 .setExpiration(new Date(System.currentTimeMillis() + tokenExpiration))
 22 
 23                 //设置主体部分
 24                 .claim("userId", userId)
 25                 .claim("username", username)
 26 
 27                 //签名部分
 28                 .signWith(SignatureAlgorithm.HS512, tokenSignKey)
 29                 .compressWith(CompressionCodecs.GZIP)
 30                 .compact();
 31         return token;
 32     }
 33 
 34     //从生成token字符串获取用户id
 35     public static Long getUserId(String token) {
 36         try {
 37             if (StringUtils.isEmpty(token)) {
 38                 return null;
 39             }
 40 
 41             Jws<Claims> claimsJws = Jwts.parser().setSigningKey(tokenSignKey).parseClaimsJws(token);
 42             Claims claims = claimsJws.getBody();
 43             Integer userId = (Integer) claims.get("userId");
 44             return userId.longValue();
 45         } catch (Exception e) {
 46             e.printStackTrace();
 47             return null;
 48         }
 49     }
 50 
 51     //从生成token字符串获取用户名称
 52     public static String getUsername(String token) {
 53         try {
 54             if (StringUtils.isEmpty(token)) return "";
 55 
 56             Jws<Claims> claimsJws = Jwts.parser().setSigningKey(tokenSignKey).parseClaimsJws(token);
 57             Claims claims = claimsJws.getBody();
 58             return (String) claims.get("username");
 59         } catch (Exception e) {
 60             e.printStackTrace();
 61             return null;
 62         }
 63     }
 64 
 65     public static void sleepUtil(int time){
 66         try {
 67             Thread.sleep(time);
 68         } catch (InterruptedException e) {
 69             e.printStackTrace();
 70         }
 71     }
 72 
 73     public static void sleepUtil(){
 74         sleepUtil(200);
 75     }
 76 
 77     /**
 78      * 判断token是否过期
 79      * @return true: 过期    false: 没有过期
 80      */
 81     public static boolean isExpiration(String token){
 82 
 83 //        sleepUtil();
 84 
 85 
 86 
 87         if(StringUtils.isEmpty(token)){
 88             System.out.println("不是合法token");
 89             return true;
 90         }
 91 
 92         try {
 93             Jws<Claims> claim = Jwts.parser().setSigningKey(tokenSignKey).parseClaimsJws(token);
 94             Claims body = claim.getBody();
 95             Date expiration = body.getExpiration();
 96 
 97             long expirationTime = expiration.getTime();
 98 
 99             long now = System.currentTimeMillis();
100 
101             if(now - expirationTime < 0){
102                 return false;
103             }
104         } catch (Exception e) {
105             System.out.println("已经过期了");
106             return true;
107         }
108 
109         return false;
110     }
111 
112     public static void main(String[] args) {
113         String token = createToken(1l, "admin");
114 
115         System.out.println(isExpiration(token));
116     }
117 }

md5  特点是单向加密,无法还原

代码

package com.atguigu.common.utils;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;


public final class MD5 {

    public static String encrypt(String strSrc) {
        try {
            char hexChars[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8',
                    '9', 'a', 'b', 'c', 'd', 'e', 'f' };
            byte[] bytes = strSrc.getBytes();
            MessageDigest md = MessageDigest.getInstance("MD5");
            md.update(bytes);
            bytes = md.digest();
            int j = bytes.length;
            char[] chars = new char[j * 2];
            int k = 0;
            for (int i = 0; i < bytes.length; i++) {
                byte b = bytes[i];
                chars[k++] = hexChars[b >>> 4 & 0xf];
                chars[k++] = hexChars[b & 0xf];
            }
            return new String(chars);
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
            throw new RuntimeException("MD5加密出错!!+" + e);
        }
    }

    public static void main(String[] args) {
        System.out.println(MD5.encrypt("111111"));
    }
}

 

标签:return,String,userId,JWT,token,static,封装,public,MD5
From: https://www.cnblogs.com/huoziqi/p/17419213.html

相关文章

  • 对Handler的一点封装
    在Android中,我们经常需要使用Handler来进行事务的异步处理。其实对于基于主线程的Handler,没有必要到处去创建。另外对于基于非主线程的Handler所对应的Thread应该在什么时候退出,始终是一个很难得抉择。因此我封装了一个基于主线程的Handler以便整个程序使用,并封......
  • 简单封装JWTUtils实现对token的创建和过期时间检查
    想要使用jwt需要先导入依赖<!--https://mvnrepository.com/artifact/io.jsonwebtoken/jjwt--><dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt</artifactId><version>0.9.1</version></depend......
  • 阿里云云直播鉴权md5hash生成
    控制台生成:在代码示例中看到生成的格式为:地址-结束时间戳-一个随机值-一个随机id-阿里云生成的鉴权key$sstring=sprintf("%s-%u-%s-%s-%s",$path,$exp,$rand,$uid,$key);$hashvalue=md5($sstring);验证:constkey="pull.hongbin.xyz-1610349434-0-0-M5EpCuE6z3";......
  • JWT 安全性总结
    一、JWT介绍    JWT全称为JsonWebToken,简单理解为用于在客户端和服务端通过Json格式传递鉴权信息,其与Session所不同的是,JWT不需要存储在服务端,而是每次请求时客户端都会携带JWT到服务端,服务端经过计算验证,确定该JWT信息是否是合法的,从而进行鉴权。JWT是一串BASE64编码,通过......
  • 常用的标准LCD驱动芯片,性价比高,稳定性好,多种封装型号选择VK1056
    型号:VK1056BVK1056C品牌:永嘉微电/VINKA封装形式:SOP24SSOP24年份:最新年份VK1056B/C概述:VK1056B/C是56点、内存映象和多功能的LCD驱动,VK1056B的软件配置特性使它适用于多种LCD应用场合,包括LCD模块和显示系统,用于连接主控制器和VK1056B的管脚只有4条,VK1056B......
  • vue3+vant3封装省市区组件
    因为后台返回的数据格式和vant不一致,所以自己遍历循环得到自己想到的格式。省市区的接口并不是一个以children格式,一次性全部获取,而是选择市的时候需要得到省的id,一层一层请求接口才能得到省市区。 父组件:1<selectArea2@addressOnFinish="onChangeArea"3......
  • 从零玩转SpringSecurity+JWT整合前后端分离-从零玩转springsecurityjwt整合前后端分离
    title:从零玩转SpringSecurity+JWT整合前后端分离date:2021-05-0614:56:57.699updated:2021-12-2617:43:19.478url:https://www.yby6.com/archives/从零玩转springsecurityjwt整合前后端分离categories:-Java分类tags:-SpringSecurity-Jwt2021年4月9日·预......
  • 【实践篇】教你玩转JWT认证---从一个优惠券聊起
    引言最近面试过程中,无意中跟候选人聊到了JWT相关的东西,也就联想到我自己关于JWT落地过的那些项目。关于JWT,可以说是分布式系统下的一个利器,我在我的很多项目实践中,认证系统的第一选择都是JWT。它的优势会让你欲罢不能,就像你领优惠券一样。大家回忆一下一个场景,如果你和你的女朋......
  • Spring Boot整合Jwt
    JWT介绍JWT是JSONWebToken的缩写,即JSONWeb令牌,是一种自包含令牌。是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准。JWT的声明一般被用来在身份提供者和服务提供者间传递被认证的用户身份信息,以便于从资源服务器获取资源。比如用在用户登录上。JWT最......
  • 通过C++/CLR封装的方式使非托管的C++、VB6.0调用.Net托管代码
    通常.Net的dll只能被加载到对应的虚拟机中运行和调用,而无法直接被低版本的.Net或C++和VB6.0等非托管代码调用。但是实际项目开发过程中我们为了兼容,不得不同时支持这些非托管代码或低版本的运行时。实际上微软提供了多种方式可以实现这种需求,如进程间通讯、COM/ActiveX、C++/CLR。......