springboot篇章整体栏目:
【二】springboot整合swagger(自定义)(超详细)
【四】springboot整合mybatis-plus(超详细)(上)
【五】springboot整合mybatis-plus(超详细)(下)
【十】springboot整合redis实现启动服务即将热点数据保存在全局以及redis(超详细)
【十一】springboot整合quartz实现定时任务优化(超详细)
【十二】springboot整合线程池解决高并发(超详细,保你理解)
【十三】springboot整合异步调用并获取返回值(超详细)
【十四】springboot整合WebService(超详细)
【十五】springboot整合WebService(关于传参数)(超详细)
【十六】springboot整合WebSocket(超详细)
【十七】springboot整合WebSocket实现聊天室(超详细)
介绍:接下来我会把学习阶段学到的框架等知识点进行整合,每一次整合是在前一章的基础上进行的,所以后面的整合不会重复放前面的代码。每次的demo我放在结尾,本次是接着上一章的内容延续的,只增加新增的或者修改的代码。
上一章对全局异常进行了整合,可以处理统一抛出错误。
1、这章整合redis,用redis存储token,实现一个用户只保存一个token,登录接口再次获取一个新的token后,前一个token则无法使用,解决一个用户可以多次登录的问题。
2、实现用户登录3次就锁定用户账户,无法再请求登录接口。
先展示一下目录结构:
第一步:修改yml配置文件
注意:是在spring:下面,database是选择存在第几个库,如下:
此处我选择的是“1”,所以存在为“1”的库。
redis的密码在安装时已经设置,也可以为空。若未安装redis,请在csdn寻找大佬的安装教程,不复杂。
第二步:新增redis操作工具类
@Component
public class RedisUtils {
@Autowired
private RedisTemplate<String, String> redisTemplate;
/**
* 读取缓存
*
* @param key
* @return
*/
public String get(final String key) {
return redisTemplate.opsForValue().get(key);
}
/**
* 写入缓存
*/
public boolean set(final String key, String value) {
boolean result = false;
try {
redisTemplate.opsForValue().set(key, value);
result = true;
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
/**
* 写入缓存,并设置过期时间
*
* @param key
* @param value
* @param timeout
* @param unit
* @return
*/
public boolean set(final String key, String value, long timeout, TimeUnit unit) {
boolean result = false;
try {
redisTemplate.opsForValue().set(key, value, timeout, unit);
result = true;
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
/**
* 更新缓存
*/
public boolean getAndSet(final String key, String value) {
boolean result = false;
try {
redisTemplate.opsForValue().getAndSet(key, value);
result = true;
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
/**
* 删除缓存
*/
public boolean delete(final String key) {
boolean result = false;
try {
redisTemplate.delete(key);
result = true;
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
}
不一定用这个,网上到处有很多更详细的工具类,按需使用。
第三步:改造token拦截器
原来的代码(上几章都有代码):
改造:
注入redis工具类。
修改方法。
到此实现了一个用户只存在一个token的效果,下面改造登录实现类代码,如下:
把登陆失败的次数存入redis,若达到3次则直接抛出异常,不再请求接口。
第三步:演示
输入正确账号密码。
将此token拿去请求接口,请求成功
重新请求登录接口,生成新的token,拿去请求刚才的接口,新token可以请求成功,旧的token无法再请求成功。
用正确的账户错误的密码登录。
错误三次之后。
本期整合到此完毕,接下来会继续更新加强整合,尽情期待。
访问地址:http://localhost:8088/swagger-ui.html或者http://localhost:8088/doc.html
demo地址:studydemo/整合swagger at main · zrc11/studydemo · GitHub
码字不易,若帮到各位,帮忙三连,感谢
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/12813.html