chuweiqiang 1 سال پیش
والد
کامیت
04761a4bca
4فایلهای تغییر یافته به همراه23 افزوده شده و 16 حذف شده
  1. 11 5
      application/api/controller/Sms.php
  2. 4 4
      application/api/controller/User.php
  3. 7 6
      application/api/hook/Sms.php
  4. 1 1
      application/extra/alisms.php

+ 11 - 5
application/api/controller/Sms.php

@@ -5,6 +5,7 @@ namespace app\api\controller;
 use app\common\controller\Api;
 use app\common\library\Sms as Smslib;
 use app\common\model\User;
+use fast\Random;
 use think\Hook;
 
 /**
@@ -52,10 +53,12 @@ class Sms extends Api
                 $this->error(__('未注册'));
             }
         }
-        if (!Hook::get('sms_send')) {
-            $this->error(__('请在后台插件管理安装短信验证插件'));
-        }
-        $ret = Smslib::send($mobile, null, $event);
+//        if (!Hook::get('sms_send')) {
+//            $this->error(__('请在后台插件管理安装短信验证插件'));
+//        }
+        $sms = ['event' => $event, 'mobile' => $mobile, 'code' => Random::numeric(config('captcha.length')), 'ip' => '', 'createtime' => time()];
+//        $ret = Smslib::send($mobile, null, $event);
+        $ret = Hook::listen('sms_check', $sms, null, true);
         if ($ret) {
             $this->success(__('发送成功'));
         } else {
@@ -111,7 +114,10 @@ class Sms extends Api
      * @param string $captcha 验证码
      */
     public function addc(){
-        $sms = ['event' => 'register', 'mobile' => 18905497965, 'code' => 123456, 'ip' => '', 'createtime' => time()];
+        $sms = ['event' => 'register', 'mobile' => 18905497965, 'code' => Random::numeric(config('captcha.length')), 'ip' => '', 'createtime' => time()];
+        if(Hook::listen('sms_check', $sms, null, true)){
+            $this->success('发送成功');
+        }
         return Hook::listen('sms_check', $sms, null, true);
     }
 }

+ 4 - 4
application/api/controller/User.php

@@ -123,10 +123,10 @@ class User extends Api
         if ($mobile && !Validate::regex($mobile, "^1\d{10}$")) {
             $this->error(__('Mobile is incorrect'));
         }
-//        $ret = Sms::check($mobile, $code, 'register');
-//        if (!$ret) {
-//            $this->error(__('Captcha is incorrect'));
-//        }
+        $ret = Sms::check($mobile, $code, 'register');
+        if (!$ret) {
+            $this->error(__('Captcha is incorrect'));
+        }
         $ret = $this->auth->register($username, $password, $email, $mobile, []);
         if ($ret) {
             $data = ['userinfo' => $this->auth->getUserinfo()];

+ 7 - 6
application/api/hook/Sms.php

@@ -20,15 +20,16 @@ class Sms
     //['event' => $event, 'mobile' => $mobile, 'code' => $code, 'ip' => $ip, 'createtime' => $time]
     function smsSend($sms)
     {
-        return '11111';
+//        return '11111';
         return $this->sendMsg($sms->mobile,['code'=>$sms->code],'code');
     }
 
     function smsCheck($sms)
     {
-    	return $this->sendMsg($sms['mobile'],['code'=>$sms['code']],'code');
+//    	return $this->sendMsg($sms['mobile'],['code'=>$sms['code']],'code');
     	if($this->sendMsg($sms['mobile'],['code'=>$sms['code']],'code')){
             $sms = \app\common\model\Sms::create(['event' => $sms['event'], 'mobile' => $sms['mobile'], 'code' => $sms['code'], 'ip' => '', 'createtime' => $sms['createtime']]);
+            return true;
         }
     }
 
@@ -64,16 +65,16 @@ class Sms
                 ])
                 ->request();
             if($result->Code=="OK"){
-                return true;
+                return $result;
             }else{
-                return false;
+                return $result;
             }
             print_r($result->toArray());
         } catch (ClientException $e) {
-            return false;
+            return $e;
             echo $e->getErrorMessage() . PHP_EOL;
         } catch (ServerException $e) {
-            return false;
+            return $e;
             echo $e->getErrorMessage() . PHP_EOL;
         }
     }

+ 1 - 1
application/extra/alisms.php

@@ -5,7 +5,7 @@
 
 return [
     //短信签名
-    "SignName"=> "XXX",
+    "SignName"=> "北京京体大文化发展",
     //阿里云keyid
     "accessKeyId"=>"LTAI5t8uTp1r27DgFFQxt6DE",
     //阿里云密钥