1. 程式人生 > 資料庫 >基於redis實現token驗證使用者是否登陸

基於redis實現token驗證使用者是否登陸

基於專案需求, 我們要實現一個基於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,

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。