SmsController.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. <?php
  2. namespace App\Http\Controllers\V1;
  3. use App\Models\User;
  4. use App\Services\Api\ErrorMsgServive;
  5. use App\Services\SmsServer;
  6. use Illuminate\Http\Request;
  7. use Illuminate\Support\Carbon;
  8. use Illuminate\Support\Facades\Mail;
  9. use App\Models\MailCode;
  10. use Illuminate\Support\Facades\Validator;
  11. use libphonenumber\PhoneNumberUtil;
  12. class SmsController extends Controller
  13. {
  14. // 发送短信验证码
  15. public function send(Request $request)
  16. {
  17. $checkResult = $this->checkMobile($request->mobile);
  18. if ('-1' == $checkResult['prefix']) { // 手机号不合法
  19. return $this->error('手机号不合法');
  20. }
  21. $request->event = $request->event ?: 'login';
  22. if ('forget' == $request->event) {
  23. if (!User::where(['mobile' => $request->mobile])->first()) {
  24. return $this->error('手机号未注册');
  25. }
  26. }
  27. $prefix = $checkResult['prefix'];
  28. $result = SmsServer::send($request->mobile, $request->event, $prefix);
  29. if (isset($result['error'])) {
  30. return $this->error('短信发送失败');
  31. }
  32. $data = [
  33. 'smsCode' => $result['smsCode'], // 注意:实际不适合把验证码返回,主要是开发方便测试,生产环境请变为 ""
  34. 'verifyKey' => $result['verifyKey'],
  35. ];
  36. return $this->success($data);
  37. }
  38. /**
  39. * @return array
  40. * 验证手机号是否合法(支持全球手机号验证)$phoneUtil->parse($mobile, "CN"),两个参数:(要验证的手机号,国家区号)
  41. * 国际区号映射关系在 vendor\giggsey\libphonenumber-for-php\src\CountryCodeToRegionCodeMap.php
  42. * 可以 在 PhoneNumberUtil::getInstance() 方法中 点击 CountryCodeToRegionCodeMap::$countryCodeToRegionCodeMap 跳过去
  43. */
  44. public static function checkMobile($mobile)
  45. {
  46. $phoneUtil = PhoneNumberUtil::getInstance();
  47. try {
  48. $cnNumberProto = $phoneUtil->parse($mobile, 'CN'); // 大陆
  49. $prefix = '-1';
  50. if ($isValid_CN = $phoneUtil->isValidNumber($cnNumberProto)) {
  51. $prefix = '86';
  52. }
  53. $checkResult = [
  54. 'prefix' => $prefix,
  55. ];
  56. return $checkResult;
  57. } catch (\libphonenumber\NumberParseException $exception) {
  58. ErrorMsgServive::write($exception, request()->url());
  59. }
  60. }
  61. /**
  62. * 发送邮箱验证码
  63. * 在 .env 文件配置如下,可测试邮件发送(最好自己申请一个邮箱获取信息)
  64. * MAIL_MAILER=smtp
  65. * MAIL_HOST=ssl://smtp.163.com
  66. * MAIL_PORT=465
  67. * MAIL_USERNAME=18738190585@163.com
  68. * MAIL_PASSWORD=VIBTDHQAYLKJYIGC
  69. * MAIL_ENCRYPTION=
  70. * MAIL_FROM_ADDRESS=18738190585@163.com
  71. * MAIL_FROM_NAME="${APP_NAME}".
  72. *
  73. * @return \Illuminate\Http\JsonResponse
  74. */
  75. public function sendEmailCode(Request $request)
  76. {
  77. $email = $request->input('email');
  78. $validator = Validator::make($request->all(), [
  79. 'email' => 'required|email',
  80. ]);
  81. if ($validator->fails()) {
  82. return $this->error($validator->errors()->first());
  83. }
  84. $code = rand(1000, 9999);
  85. $notice = '本次验证码是【 ' . $code . ' 】 有效期 5 分钟';
  86. $subject = '邮箱验证通知';
  87. try {
  88. Mail::raw($notice, function ($message) use ($email, $subject) {
  89. $message->subject($subject);
  90. $message->to($email);
  91. });
  92. $mailCode = new MailCode();
  93. $mailCode->account = $email;
  94. $mailCode->code = $code;
  95. $mailCode->state = 0;
  96. $mailCode->created_at = date('Y-m-d H:i:s');
  97. $mailCode->save();
  98. return $this->success();
  99. } catch (\Exception $e) {
  100. return $this->error($e->getMessage());
  101. }
  102. }
  103. // 判断邮箱验证码 5分钟有效期 (这不是个API接口:哪里需要就放到哪里验证)
  104. public static function isEmailCodeRight($email, $code)
  105. {
  106. $result = MailCode::query()
  107. ->where('account', $email)
  108. ->where('code', $code)
  109. ->where('state', 0)
  110. ->where('created_at', '>', Carbon::now()->subMinutes(5))
  111. ->orderBy('id', 'desc')
  112. ->first();
  113. if (!$result) {
  114. return false;
  115. }
  116. $result->state = 1; // 验证通过就失效
  117. $result->save();
  118. return true;
  119. }
  120. }