gpt4 book ai didi

ssm项目实现用户登陆持久化(token)

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 24 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章ssm项目实现用户登陆持久化(token)由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

用户登录持久化就是每次访问不用账号密码来校验身份,在用户登录第一次之后会返回一个token字符串,之后的访问客户端将这个token加到请求体里发给服务器就可以验证身份了.

利用jedis和jwt创建用户token 。

1、jwt创建token

maven依赖:

?
1
2
3
4
5
<dependency>
     <groupid>com.auth0</groupid>
     <artifactid>java-jwt</artifactid>
     <version>3.3.0</version>
</dependency>

创建jwt工具类 。

用于创建token和解析token 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
import com.auth0.jwt.jwt;
import com.auth0.jwt.jwtverifier;
import com.auth0.jwt.algorithms.algorithm;
import com.auth0.jwt.interfaces.claim;
import com.auth0.jwt.interfaces.decodedjwt;
 
public class jwtutils {
 
     /**
      * 公钥
      */
     private static string secret = "qiang" //此处随便设置一个自己的加密符号
     public static string createtoken(int id, string username,
                                       string type) throws exception {
         // 签发时间
         date iatdate = new date ();
 
         // 过期时间,7天时间
         calendar nowtime = calendar.getinstance();
         nowtime.add(calendar.hour, 24 * 7);
         date experiesdate = nowtime.gettime();
 
         map<string, object> map = new hashmap<string, object>();
         map.put( "alg" , "hs256" );
         map.put( "typ" , "jwt" );
         string token = jwt.create()
                 .withheader(map)
                 .withclaim( "id" , id)
                 .withclaim( "username" , username)
                 .withclaim( "type" , type)
                 .withexpiresat(experiesdate) // 设置过期的日期
                 .withissuedat(iatdate) // 签发时间
                 .sign(algorithm.hmac256(secret)); // 加密
         return token;
     }
 
     /**
      * 解密
      */
 
     public static map<string, claim> verifytoken(string token) throws exception {
         jwtverifier verifier = jwt. require (algorithm.hmac256(secret)).build();
         decodedjwt jwt = null;
         try {
             jwt = verifier.verify(token);  //核实token
         } catch (exception e) {
             throw new exception( "登录过期" );
         }
         return jwt.getclaims();  //返回的是解析完的token,是一个map,里面有id,username,type键值对
     }
}

2、jedisutil缓存token

首先讲讲jedis,jedis是集成了redis的一些命令操作,将其封装的java客户端,一般在其上封装一层作为业务使用,封装如下:

首先导入maven包,这里也需要启动redis服务 。

?
1
2
3
4
5
<dependency>
     <groupid>redis.clients</groupid>
     <artifactid>jedis</artifactid>
     <version>2.9.0</version>
</dependency>

然后设计一个jedis工具类将其封装 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
import redis.clients.jedis.jedis;
 
public class jedisutils {
 
     private static jedis jedis;
     //初始化
     private static void init() {
         jedis = new jedis( "localhost" );
     }
     //在redis中设置键值对存储
     public static void settoken(string id, string token, int day) {
         int second = day * 60 * 60 * 24;
         jedisutils.init();
         jedis.set(string.valueof(id), token); //根据id存储token
         jedis.expire(string.valueof(id), second);  //设置token持续时间
     }
 
     public static string gettoken(string id) {
         jedisutils.init();
         string token = jedis.get(string.valueof(id));  //获取token
         return token;
     }
}

 到此这篇关于ssm项目实现用户登陆持久化(token)的文章就介绍到这了,更多相关ssm 用户登陆持久化内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。

原文链接:https://blog.csdn.net/sinat_41905822/article/details/89043642 。

最后此篇关于ssm项目实现用户登陆持久化(token)的文章就讲到这里了,如果你想了解更多关于ssm项目实现用户登陆持久化(token)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com