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
    评论
Redis可以用来实现短信验证码功能,具体步骤如下: 1. 生成验证码:使用随机数生成器生成一个6位数字的验证码,并将其存储到Redis中,以手机号作为key,验证码作为value,同时设置过期时间为5分钟。 2. 发送验证码:将验证码发送到用户手机上,可以使用短信平台或者第三方SDK来实现。 3. 验证验证码:用户输入验证码后,从Redis中读取对应手机号的验证码,与用户输入的验证码进行比对,如果一致则验证通过,否则验证失败。 以下是使用Redis实现短信验证码的代码示例(使用Python语言): ``` import redis import random import time # 连接Redis r = redis.Redis(host='localhost', port=6379, db=0) # 生成验证码 def generate_verification_code(phone): verification_code = random.randint(100000, 999999) r.set(phone, verification_code, ex=300) # 设置过期时间为5分钟 return verification_code # 验证验证码 def verify_verification_code(phone, verification_code): stored_code = r.get(phone) if stored_code is None: return False if int(stored_code) != verification_code: return False r.delete(phone) # 验证通过后删除验证码 return True # 示例代码 phone = '13812345678' code = generate_verification_code(phone) print(code) time.sleep(2) # 模拟发送验证码到用户手机上的过程 result = verify_verification_code(phone, code) print(result) ``` 需要注意的是,由于Redis是内存数据库,如果服务器重启或者Redis进程被杀死,存储在Redis中的数据会丢失,因此需要根据实际情况进行合理的持久化和备份。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值