redis解决分布式session共享

Session是服务器用来保存用户操作的一系列会话信息,由Web容器进行管理。单机情况下,不存在Session共享的情况,分布式情况下,如果不进行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);
		}
	}
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值