Session是服务器用来保存用户操作的一系列会话信息,由Web容器进行管理。单机情况下,不存在Session共享的情况,分布式情况下,如果不进行Session共享会出现请求落到不同机器要重复登录的情况,这里我使用了redis来解决session的共享问题
用户登录逻辑,需要处理session共享问题,将用户信息,存储在redis中将key作为数据返回页面时,放到cookie中,只要cookie中有key,后续访问逻辑系统时,都会携带这个key,从而可以处理获取redis的数据使用.
将登录信息保存到redis中
@Autowired
private RedisCumUtils redis;
public String doLogin(User user) {
//查询一下数据库数据,是否存在userExist
User exist=userMapper.selectExist(user);
try{
if(exist==null){//登录失败
return "";
}else{
//表示成功,存储在redis返回key值
String ticket=MD5Util.md5("EM_TICKET"+System.currentTimeMillis()+exist.getUserId());
//准备value值,mapper转化user为json字符串
String userJson=MapperUtils.MP.writeValueAsString(exist);
//set数据到redis供后续逻辑使用
redis.addOrUpdateExpire(ticket, userJson, 60*30);
//验证最多一个用户登录,顶替登录逻辑
//TODO
return ticket;
}
}catch(Exception e){
e.printStackTrace();
return "";
}
}
将key存到cookie中
@ResponseBody
public SysResult doLogin(User user,HttpServletRequest request,
HttpServletResponse response){
//获取的user对象只有userName和userPassword
String ticket=userService.doLogin(user);
//如果ticket为空相当于登录失败
if(!StringUtils.isNotEmpty(ticket)){//ticket为空
return SysResult.build(0, "", null);
}
else{//不为空登录成功
//返回成功信息之前,需要将ticket放到cookie中
//调用cookie进行set值
CookieUtils.setCookie(request, response,
"JT_TICKET", ticket);
return SysResult.build(1, "", null);
}
}