这篇文章主要讲解了“SpringBoot怎么整合SpringSession实现分布式登录”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot怎么整合SpringSession实现分布式登录”吧!
比如两个域名:
aaa.yupi.com
bbb.yupi.com
如果要共享 cookie,可以种一个更高层的公共域名,比如 yupi.com
用户在 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
效果:
/**
* @author 刘宇浩
*/
@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实现分布式登录这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。