注意:建议阅读顺序是1-4(用户首次登陆),理解后再阅读5-6(用户再次登陆,拦截),10和11用于帮助理解
1 因为sso实质是在maven项目上的加固,所以首先需要一个maven项目,创建基本项目过程略过
2 导入名为spring-boot-starter-data-redis的jar包
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
3(login) 在控制器接收到了用户登陆请求以及用户登陆的参数(username&password),但是我们应该在service层进行管理,所以控制器不做处理将参数传至service4(login) service获取到了参数以后,调用实现类进行登陆,登陆完成以后应当将用户登陆信息保存至redis数据库,避免多次登录
代码如下:
//StringRedisTemplate是对redis数据库操作的封装类,与它功能类似的还有RedisTemplate,在下方第10点详细说明
private StringRedisTemplate stringRedisTemplate;
//关键步骤一:把登录成功的用户信息以token作为key,以用户对象的json作为值写入redis
a)//此处UUID是java.util包下的对象,它调用randomUUID()可以生成随机字符
String token = UUID.randomUUID().toString();
b)//此处ObjectMapper包名为com.fasterxml.jackson.databind.ObjectMapper,该对象的writeValueAsString将数据书写为String类型
String json = new ObjectMapper().writeValueAsString(LoginUser);
c)//此处opsForValue()是redis提供的操作字符串方法,在下方第11点详细说明,参数:token-存入redis的key,json-存入redis的value,1800-过期时间,TimeUnit.SECONDS-过期时间的单位
stringRedisTemplate.opsForValue().set(token, json, 1800, TimeUnit.SECONDS);
//关键步骤二:把token信息返回的调用方
//Result.ok()是一个用来保存数据的类,其中包含很多例如ok()的静态方法,用于返回结果,非必须
return Result.ok().setCode(200).setData(token).setMessage("登录成功");
//关键步骤三:在前端使用js将用户登陆信息存入cookie
//把登录成功的token写入cookie,使其他项目能读取到,然后返回其它系统主页
$.cookie("token", data.data, {path: "/", domain: ".cdzg.com"});\
location.href = "http://bbs.cdzg.com:8002/index.html";
5(login2) 在控制器接收到了用户重复请求以及用户登陆的参数(username&password),但是将参数传给service管理6(login2) service获取到了参数,为了避免用户重复登陆,需要判断用户是否已经登陆
//获取redis数据库存入的token,此处token是前端从cookie取出的key值
String json = stringRedisTemplate.opsForValue().get(token);
//进行判断json是否为空,如果为空或者超时则返回登陆界面,让用户重新登陆,否则刷新登陆时间
//更新token的过期时间
stringRedisTemplate.expire(token, 1800, TimeUnit.SECONDS);
10 StringRedisTemplate和RedisTemplate都是redis提供的工具,能够对redis数据库进行crud,
区别是他们使用的序列化类不同,
11 redis提供了操作多种数据的方法
StringRedisTemplate.opsForValue(); //操作字符串
StringRedisTemplate.opsForHash(); //操作hash
StringRedisTemplate.opsForList(); //操作list
StringRedisTemplate.opsForSet(); //操作set
StringRedisTemplate.opsForZSet(); //操作有序set
如果有需要修改的地方欢迎私信联系我,我会尽快回复并且修改:D