LoginValidate.php 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. <?php
  2. namespace app\shopapi\validate;
  3. use app\common\basics\Validate;
  4. use app\common\model\shop\ShopAdmin;
  5. use think\facade\Cache;
  6. /**
  7. * 商家移动端登录验证
  8. * Class LoginValidate
  9. * @package app\shopapi\validate
  10. */
  11. class LoginValidate extends Validate
  12. {
  13. protected $rule = [
  14. 'client' => 'require|in:1,2,3,4,5,6',
  15. 'account' => 'require',
  16. 'password' => 'require|checkPassword',
  17. ];
  18. protected $message = [
  19. 'password.require' => '请输入密码',
  20. 'password.checkPassword' => '账号或密码错误',
  21. 'client.require' => '请输入客户端',
  22. 'client.in' => '无效的客户端',
  23. ];
  24. /**
  25. * @notes 校验密码
  26. * @param $password
  27. * @param $other
  28. * @param $data
  29. * @return bool|string
  30. * @author 段誉
  31. * @date 2021/11/9 16:02
  32. */
  33. protected function checkPassword($password, $other, $data)
  34. {
  35. if (false === $this->safe()) {
  36. $this->message['password.password'] .= ':多次输入错误';
  37. return false;
  38. }
  39. $admin_info = (new ShopAdmin())->alias('a')
  40. ->field('a.*')
  41. ->join('shop s', 's.id = a.shop_id')
  42. ->where(['a.account' => $data['account'], 'a.del' => 0])
  43. ->find();
  44. if (empty($admin_info)) {
  45. $this->safe(true);
  46. return '账号不存在';
  47. }
  48. if ($admin_info['disable']) {
  49. return '账号被禁用';
  50. }
  51. $password = generatePassword($password, $admin_info['salt']);
  52. if ($password != $admin_info['password']) {
  53. $this->safe(true);
  54. return false;
  55. }
  56. return true;
  57. }
  58. /**
  59. * 连续30分钟内15次输错密码,无法登录
  60. * @param bool $add
  61. * @return bool
  62. */
  63. protected function safe($add = false)
  64. {
  65. $cache_name = 'shop_api_login_error_count' . request()->ip();
  66. if ($add) {
  67. $admin_login_error_count = Cache::get($cache_name);
  68. $admin_login_error_count++;
  69. Cache::tag('shop_api_login_error_count')->set($cache_name, $admin_login_error_count, 1800);
  70. }
  71. $count = Cache::get($cache_name);
  72. if (!empty($count) && $count >= 15) {
  73. return false;
  74. }
  75. return true;
  76. }
  77. }