Redis实现短信验证码

       现在app登录都有个验证码登录功能, 至少包含2个接口:获取验证码和登录。 

      后台服务需要缓存验证码、账号和该验证码的对应关系以及设置超过时间(一般是60秒)等;  这个验证码就需要中间件来存储。 Redis是按Key-Value方式存储数据, 它还提供了超时自动删除功能, 适合用在短信验证码需求上。

       参考: Redis实现中间件


一、  点击“获取验证码”按钮的示例代码:

  @RequestMapping("/getloginsms")
    @ResponseBody
    public DemoEntity getSmsCode(@RequestParam(value = "accountid") String accountid) {
        Jedis jedis = RedisProvider.getJedis();
        DemoEntity entity = new DemoEntity();
        String pwd = null;

        //1. 判断是否缓存该账号验证码
        boolean isExist = jedis.exists(accountid + "_smslogin");
        if (isExist) {
            pwd = jedis.get(accountid + "_smslogin");   //从redis取出验证码

            //设置返回对象的参数
            return  entity;
        } else {
            //没找到该账号的验证码,新生成验证码
            pwd = TestRedis.getRandom();

            jedis.setex(accountid + "_smslogin", 60, pwd);   //缓存验证码并设置超时时间
        }


        //设置返回值参数
        entity.setPwd(pwd);

        return entity;
    }
    每个账号对应唯一的key,为了区分redis的key值, 要添加前缀或者后缀, 本例中是添加后缀_smslogin。

    关键代码: jedis.setex(accountid + "_smslogin", 60, pwd) , 60表示超过60秒后自动删除该键值。

     生成验证码函数,该函数返回6位随机数字。 

    public static String getRandom() {
        String num = "";
        for (int i = 0 ; i < 6 ; i ++) {
            num = num + String.valueOf((int) Math.floor(Math.random() * 9 + 1));
        }
        return num;
    }


二、登录接口示例:

  @RequestMapping("/loginsms")
    @ResponseBody
    public DemoEntity logingBySms(@RequestParam(value = "accountid") String accountid,
                                    @RequestParam(value = "smscode") String code) {
        Jedis jedis = RedisProvider.getJedis();
        String pwd = null;
        //1. 判断是否缓存该账号验证码
        boolean isExist = jedis.exists(accountid + "_smslogin");
        if (isExist) {
            pwd = jedis.get(accountid + "_smslogin");   //从redis取出验证码
        } else {
            //没找到该账号的验证码, 返回错误和提示信息

        }

        //2. 逻辑判断 一般会对验证码code做加密处理,所有要解密或用相同参数加密pwd参数。
        .....


        //3. 一切OK后删除验证码
        jedis.del(accountid + "_smslogin");

        DemoEntity resp = new DemoEntity();
        //设置返回值参数

        return resp;
    }

      登录接口会比较入参验证码参数和缓存在中间件redis里的验证码, 一般app在传输密码字段时会加密; 所以服务端可以先解密或者加密密码明文。



         因为Redis提供了超时自动删除键值功能, 而且在多个tomcat节点可以访问同一个redis, 所以用Redis实现验证码功能。



PS: Redis还提供了分布式锁功能, 是现在互联网公司使用的主流中间件。


  

阅读终点,创作起航,您可以撰写心得或摘录文章要点写篇博文。去创作
  • 4
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

brycegao321

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值