基於redis實現token驗證使用者是否登陸
阿新 • • 發佈:2020-01-09
基於專案需求, 我們要實現一個基於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,
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。