欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

基于redis实现token验证用户是否登陆

程序员文章站 2023-12-31 21:33:28
基于项目需求, 我们要实现一个基于redis实现token登录验证,该如何实现呢: 后端实现: 1.引入redis相关的依赖

基于项目需求, 我们要实现一个基于redis实现token登录验证,该如何实现呢:

后端实现:

1.引入redis相关的依赖

<dependency>
 <groupid>org.springframework.boot</groupid>
 <artifactid>spring-boot-starter-data-redis</artifactid>
</dependency>
<dependency>
 <groupid>org.springframework.session</groupid>
 <artifactid>spring-session-data-redis</artifactid>
 <version>2.0.5.release</version>
</dependency>

2.controller层生成token信息并存入redis中

//若用户登录验证成功后将对应的登陆信息和登陆凭证一起存入redis中
//生成登陆凭证token uuid
string uuidtoken= uuid.randomuuid().tostring();
uuidtoken=uuidtoken.replace("-","");
 
//将token和用户登录态之间建立联系
redistemplate.opsforvalue().set(uuidtoken,usermodel);
redistemplate.expire(uuidtoken,1, timeunit.hours);
 
// 下发token
return commonreturntype.create(uuidtoken);

3.需要验证的登陆的地方调用即可

 string token = httpservletrequest.getparametermap().get("token")[0];
 if (stringutils.isempty(token)) {
 throw new businessexception(embusinesserror.user_not_login, "用户还未登陆,不能下单");
 }
 //获取用户的登陆信息
 usermodel usermodel= (usermodel) redistemplate.opsforvalue().get(token);
 if(usermodel==null){
 throw new businessexception(embusinesserror.user_not_login, "用户还未登陆,不能下单");
 }
 
 ordermodel ordermodel = orderservice.creatorder(usermodel.getid(), itemid, promoid, amount);
 return commonreturntype.create(null);

前端实现

1.从返回值中取出token并存入localstorage

if(data.status == "success") {
 alert("登陆成功");
 //取出token放入localstorage
 var token = data.data;
 window.localstorage["token"] = token;
 window.location.href = "listitem.html";
}

2.验证用户是否登陆

var token = window.localstorage["token"];
 if(token == null){
 alert("没有登录,不能下单");
 window.location.href="login.html" rel="external nofollow" ;
 return false;
 } 

3.当然,需要把token传入后端再校验一次

url:"http://"+g_host+"/order/createorder?token="+token,

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

上一篇:

下一篇: