Session是服务器用来保存用户操作的一系列会话信息,由Web容器进行管理。单机情况下,不存在Session共享的情况,分布式情况下,如果不进行Session共享会出现请求落到不同机器要重复登录的情况,这里我使用了redis来解决session的共享问题

redis session共享原理 redis做session共享_redis session共享原理

用户登录逻辑,需要处理session共享问题,将用户信息,存储在redis中将key作为数据返回页面时,放到cookie中,只要cookie中有key,后续访问逻辑www.xxx.com系统时,都会携带这个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);
		}
	}