Python 官方文档:入门教程 => 点击学习
目录Session 共享为什么服务器 A 登录后,请求发到服务器 B,不认识该用户?解决方案SpringBoot整合springSession实现分布式登录Session 共享 比如
比如两个域名:
用户在 A 登录,所以 session(用户登录信息)存在了 A 上
结果请求 B 时,B 没有用户信息,所以不认识。
共享存储 ,而不是把数据放到单台服务器的内存中
引入 redis,能够操作 redis:
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-data-Redis -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<version>2.6.4</version>
</dependency>
引入 spring-session 和 redis 的整合,使得自动将 session 存储到 redis 中:
<!-- Https://mvnrepository.com/artifact/org.springframework.session/spring-session-data-redis -->
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-data-redis</artifactId>
<version>2.6.3</version>
</dependency>
修改 spring-session 存储配置 spring.session.store-type
默认是 none,表示存储在单台服务器
store-type: redis,表示从 redis 读写 session
redis:
host: localhost
port: 6379
session:
timeout: 60
store-type: redis
效果:
@RestController
@RequestMapping("/session")
public class SessionController {
public static final String key = "USERLOGINSTATE";
@GetMapping("/set")
public Result setSession(HttpServletRequest request) {
User user = new User();
user.setClassName("21软件3");
user.setName("lyl");
request.getSession().setAttribute(key, user);
return ResultGenerator.genSuccessResult(200, "成功");
}
@GetMapping("/get")
public Result getSession(HttpServletRequest request){
User userloginstate = (User)request.getSession().getAttribute(key);
System.out.println(userloginstate.getName());
System.out.println(userloginstate.getClassName());
return ResultGenerator.genSuccessResult(200,"成功");
}
}
到此这篇关于SpringBoot整合SpringSession实现分布式登录详情的文章就介绍到这了,更多相关SpringBoot整合SpringSession 内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: SpringBoot整合SpringSession实现分布式登录详情
本文链接: https://lsjlt.com/news/171696.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0