You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

134 lines
3.5 KiB

  1. <?php
  2. namespace app\common\library;
  3. use think\Hook;
  4. /**
  5. * 短信验证码类
  6. */
  7. class Sms
  8. {
  9. /**
  10. * 验证码有效时长
  11. * @var int
  12. */
  13. protected static $expire = 120;
  14. /**
  15. * 最大允许检测的次数
  16. * @var int
  17. */
  18. protected static $maxCheckNums = 10;
  19. /**
  20. * 获取最后一次手机发送的数据
  21. *
  22. * @param int $mobile 手机号
  23. * @param string $event 事件
  24. * @return Sms
  25. */
  26. public static function get($mobile, $event = 'default')
  27. {
  28. $sms = \app\common\model\Sms::
  29. where(['mobile' => $mobile, 'event' => $event])
  30. ->order('id', 'DESC')
  31. ->find();
  32. Hook::listen('sms_get', $sms, null, true);
  33. return $sms ? $sms : null;
  34. }
  35. /**
  36. * 发送验证码
  37. *
  38. * @param int $mobile 手机号
  39. * @param int $code 验证码,为空时将自动生成4位数字
  40. * @param string $event 事件
  41. * @return boolean
  42. */
  43. public static function send($mobile, $code = null, $event = 'default')
  44. {
  45. $code = is_null($code) ? mt_rand(1000, 9999) : $code;
  46. $time = time();
  47. $ip = request()->ip();
  48. $sms = \app\common\model\Sms::create(['event' => $event, 'mobile' => $mobile, 'code' => $code, 'ip' => $ip, 'createtime' => $time]);
  49. $result = Hook::listen('sms_send', $sms, null, true);
  50. if (!$result) {
  51. $sms->delete();
  52. return false;
  53. }
  54. return true;
  55. }
  56. /**
  57. * 发送通知
  58. *
  59. * @param mixed $mobile 手机号,多个以,分隔
  60. * @param string $msg 消息内容
  61. * @param string $template 消息模板
  62. * @return boolean
  63. */
  64. public static function notice($mobile, $msg = '', $template = null)
  65. {
  66. $params = [
  67. 'mobile' => $mobile,
  68. 'msg' => $msg,
  69. 'template' => $template
  70. ];
  71. $result = Hook::listen('sms_notice', $params, null, true);
  72. return $result ? true : false;
  73. }
  74. /**
  75. * 校验验证码
  76. *
  77. * @param int $mobile 手机号
  78. * @param int $code 验证码
  79. * @param string $event 事件
  80. * @return boolean
  81. */
  82. public static function check($mobile, $code, $event = 'default')
  83. {
  84. $time = time() - self::$expire;
  85. $sms = \app\common\model\Sms::where(['mobile' => $mobile, 'event' => $event])
  86. ->order('id', 'DESC')
  87. ->find();
  88. if ($sms) {
  89. if ($sms['createtime'] > $time && $sms['times'] <= self::$maxCheckNums) {
  90. $correct = $code == $sms['code'];
  91. if (!$correct) {
  92. $sms->times = $sms->times + 1;
  93. $sms->save();
  94. return false;
  95. } else {
  96. $result = Hook::listen('sms_check', $sms, null, true);
  97. return $result;
  98. }
  99. } else {
  100. // 过期则清空该手机验证码
  101. self::flush($mobile, $event);
  102. return false;
  103. }
  104. } else {
  105. return false;
  106. }
  107. }
  108. /**
  109. * 清空指定手机号验证码
  110. *
  111. * @param int $mobile 手机号
  112. * @param string $event 事件
  113. * @return boolean
  114. */
  115. public static function flush($mobile, $event = 'default')
  116. {
  117. \app\common\model\Sms::
  118. where(['mobile' => $mobile, 'event' => $event])
  119. ->delete();
  120. Hook::listen('sms_flush');
  121. return true;
  122. }
  123. }