使用redis实现手机验证码的一个例子

	@PostMapping("getYzm")
	@ResponseBody
	public Result getYzm(HttpServletRequest request) {
		String mobile = HttpParameterUtil.getString(request, "mobile");
		Integer sguserid = CampSessionDataHelper.getSguserid(request);
		String dateStr = DateUtil.getCurDate();
		
		String countKey = SysConstant.MOBILE_VERIFY_CODE_REDIS_NAME_SPACE+"count_"+dateStr + "_" + mobile;
		String valueKey = SysConstant.MOBILE_VERIFY_CODE_REDIS_NAME_SPACE+campCode + "_" + mobile;
		// 验证短信验证次数
		Integer count = (Integer) redisTemplate.opsForValue()
				.get(countKey);
		if (count != null && count >= 5) {
			return Result.error(-1, "验证码次数已超过限制,请明天再尝试");
		}
		String res = (String) redisTemplate.opsForValue().get(valueKey);
		if (res != null) {
			return Result.error(-1, "请勿重复点击");
		}
		String templateid = campCfgSubmitInfo.getMobileVerifyCodeSmsTplid();
		int code = RandomUtil.random(1000, 9999);
        //发送验证码逻辑
		JSONObject json = PsvHttpUtil.post(PsvConstant.SEND_MOBILE_VERIFY_CODE_URL, params);
		if (json.getInt("error") != 0) {
			return Result.error(-1, json.getString("errmsg"));
		}
		// 设置到redis,并且设置过期时间为60s
		redisTemplate.opsForValue().set(valueKey, code, 60L, TimeUnit.SECONDS);
		// 增加当天访问验证码次数
		if(count == null || count ==0) {
			//设置为两天过期
			redisTemplate.opsForValue().set(countKey, 1, 2L, TimeUnit.DAYS);
		}else {
			redisTemplate.opsForValue().increment(countKey, 1L);
		}
		return Result.success(code);
	}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值