一、前台页面向后台传参
1、@RequestBody
用来接收post请求里面传过来的参数
2、@Pathvariable
用来接收Restful格式的传参
3、@RequestParam
将请求参数绑定至方法参数
二、将session存到redis可支持分布式
1、利用中间件
引入依赖:
在启动类上配置注解和缓存有效时间
application.properties配置
我这里使用了一个单节点存储session,一个集群存储其他。
存session的话是不需要去set的,他会自动将你的session存入redis
你对session的操作就和往常一样就行了。
2、使用redis+cookie+口令方式
具体逻辑:SSO单点登录系统登陆成功后将user信息存入redis,返回token口令,
口令被WEB前台存入cookie。方便页面使用。
针对以上两种方案给出用户顶替登录和续约逻辑
1、对于使用session方案
用一个List保存已登录的用户
每一次登录都去检查这个userId,存在即拦截此次登录
注销时删除cookie并删除此列表里的同名userId
用到了session,所以续约不成问题
2、对于redis+cookie+口令的方式
对每一个用户信息进行一个唯一的key存在redis
下次登录会覆盖这个key,并更新一下cookie里的token
就可以制造唯一登录
redis的ttl命令可以查看redis里token的有效时间