Redis代替session实现登录业务

1.使用session实现登录的问题

每个服务器中都有一份属于自己的session,这会导致多台服务器情况下的数据不统一。

使用session拷贝会出现两大问题:

1、每台服务器中都有完整的一份session数据,服务器压力过大。

2、session拷贝数据时,可能会出现延迟

2.redis代替session

原理:

redis数据本身便是共享可以解决掉session共享问题,且可以利用threadLocal的特性,将用户重要数据以token为key存入redis中,自定义拦截器将请求拦截校验redis中是否有用户数据,如果有,将用户数据存入当前线程中。

代码片段如下:

1.获取验证码
2.登录验证
3.定义拦截器

第一层拦截器:拦截所有请求,用于判断且存入用户信息。

第二层拦截器:用于拦截需要具有用户信息的请求.

拦截器注册

3.总结:

1.用户登录时,通过生成的token为key存入redis中,并将token返回给前端。

2.第一层拦截器:验证前端的请求头是否有token,如果有,通过token拿到redis中的用户信息,并存入ThreadLocal中。

3.第二层拦截器:验证ThreadLocal中是否具有用户信息,来验证是否用户登录。

相关推荐
一定要AK1 天前
Spring 入门核心笔记
java·笔记·spring
A__tao1 天前
Elasticsearch Mapping 一键生成 Java 实体类(支持嵌套 + 自动过滤注释)
java·python·elasticsearch
KevinCyao1 天前
java视频短信接口怎么调用?SpringBoot集成视频短信及回调处理Demo
java·spring boot·音视频
迷藏4941 天前
**发散创新:基于Rust实现的开源合规权限管理框架设计与实践**在现代软件架构中,**权限控制(RBAC)** 已成为保障
java·开发语言·python·rust·开源
wuxinyan1231 天前
Java面试题47:一文深入了解Nginx
java·nginx·面试题
新知图书1 天前
搭建Spring Boot开发环境
java·spring boot·后端
冰河团队1 天前
一个拉胯的分库分表方案有多绝望?整个部门都在救火!
java·高并发·分布式数据库·分库分表·高性能
洛_尘1 天前
Java EE进阶:Linux的基本使用
java·java-ee
宸津-代码粉碎机1 天前
Spring Boot 4.0虚拟线程实战调优技巧,最大化发挥并发优势
java·人工智能·spring boot·后端·python
不知名的老吴1 天前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存