借助 Rides 实现输入密码错误限制次数

借助 Rides 实现输入密码错误限制次数

  • 限制时间为1天(86400s);

  • 一小时内错误次数>=6;

      key => user_no:AD576dfdcc650e0password_error_count
      value => 1530862696:1
    

验证密码前逻辑

function passwordErrorCount($userNo)
{
    $redisHost = '127.0.0.1';
    $redisProt = 6379;
    $redisPwd = 'password';
    $redis = new Redis();

    $redis->connect($redisHost, $redisProt);
    $redis->auth($redisPwd);

    $key = 'userNo:' . $userNo . 'password_error_count';
    list($time, $count) = explode(':', $redis->get($key));

    $ban = $time + 86400;
    
    $result = [
        'status' => true,
        'message' => "无限制"
    ];
        
    if (time() <= $ban && $count >= 6) {
        $result = [
            'status' => false,
            'message' => "登录失败", "登录操作被限制,请在" . date('Y-m-d H:i:s', $ban) . "后重试"
        ];
    }
    return $result;
}

验证密码

function auth()
{
    $user_no = 'U-test';
    $pwd = '123456';

    $result = passwordErrorCount($user_no);

    // 判断是否有登录限制
    if($result['status'] === false){    
        $message = $result['message'];
    }elseif ($pwd === '******') {
        $message = '登录成功';
    }else{
        $message = '密码错误';
        restrict($user_no);
    }
}

输入密码错误后逻辑

function restrict($userNo)
{
    $redisHost = '127.0.0.1';
    $redisProt = 6379;
    $redisPwd = 'password';
    $redis = new Redis();

    $redis->connect($redisHost, $redisProt);
    $redis->auth($redisPwd);

    $key = 'userNo:' . $userNo . 'password_error_count';

    list($time, $count) = explode(':', $redis->get($key));

    // 判断是否在一小时内多次出错

    $value = implode(':', array(time(), 1));
    if (date('YmdH', $time) === date('YmdH', time())) {
        $value = implode(':', array(time(), $count + 1));
    }
    $redis->set($key, $value);
}

  • 在写的过程中写了几个if嵌套感觉比较恶心.也不会优化,向有经验的大佬请教略有收获.

  • 慢慢锻炼,加强自己的思维.

      // 自己写的
      // 判断是否有登录限制
      if ($result['status'] === true) {
          // 判断密码是否正确
          if ($pwd === '*****') {
              $message = '登录成功';
          } else {
              $message = '密码错误';
              restrict($user_no);
          }
      } else {
          $message = $result['message'];
      }
    

      // 请教后写的
      // 判断是否有登录限制
      if($result['status'] === false){    
          $message = $result['message'];
      }elseif ($pwd === '******') {
          $message = '登录成功';
      }else{
          $message = '密码错误';
          restrict($user_no);
      }
    
    • 没有了嵌套,看起来也清晰了很多
    • 因为最后密码失败要调用一个方法,所以 else 很有必要

    如果没有调用方法,可以提前赋值:

    // 判断是否有登录限制
    $message = '密码错误';
    if($result['status'] === false){    
        $message = $result['message'];
    }elseif ($pwd === '******') {
        $message = '登录成功';
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明AGI阅读 16,018评论 3 119
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,991评论 19 139
  • 蓝海星空下 一枝花朵儿在流浪 她有好多话儿在心间 她,欲言又止 低眉抿唇地伸展着身姿 一个人生自己的气 一阵海风吹...
    伍月的晴空阅读 404评论 20 15
  • (一)起篇 【1】人之初,性本善,性相近,习相远。苟不教,性乃迁,教之道,贵以专。 【2】昔孟母,择邻处,子不学...
    h璐瑶h阅读 550评论 0 0
  • 【一、内在心理状态】 第6天·21天OH卡美颜瘦身课 #玩卡不卡·每日一抽# 每一位都可以通过这张卡片觉察自己: ...
    简法生活阅读 321评论 0 0