今天要讲的内容是刚刚完成的讲师管理系统中的单点登录功能,之后还会介绍整个项目其他功能点和技术点。什么是单点登录?其实很好理解,首先假设一个场景,在一个Spring Boot项目中有许多微服务模块,你只需要通过登录一个模块就可以访问其他模块。
单点登录常见的方式有三种
第一种:session广播机制,登录一个模块之后通过session复制的方式,把登录信息复制给其他模块,实现其他模块的访问
第二种:cookie+redis
1.在项目中的任何一个模块进行登路之后,把数据放到两个地方。
(1)redis:在key:生成唯一随机值(ip,用户id等),value:用户数据
(2)cookie:把redis生成的key值放入cookie里面
2.访问项目中其他模块,发送请求带着cookie进行发送,获取cookie值,通过cookie进行操作:把cookie获取值,到redis进行查询,根据key查询,如果查询到数据就是登录
第三种:使用token实现
1.在项目某个模块进行登录之后,按照规则生成字符串,把登录之后用户包含生成字符串里面,把字符串返回
(1)可以把字符串通过cookie返回
(2)把字符串通过地址返回
2.再去访问项目其他模块,在访问的模块里面获取地址栏字符串,根据字符串获取用户信息。如果能获取到就登录