laravel框架下php手机短信验证码实现流程

Posted on Posted in PHP教程

本篇文章给大家带来的内容是关于 laravel框架下php手机短信验证码实现流程,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

具体短信服务提供商大家可以自由选择。

1,实现流程

输入手机号,点击获取验证码
提交正确的短信验证码后,注册完成

2,实现思路图

laravel框架下php手机短信验证码实现流程

3,注册 云片,以及开发信息认证,模板设置,这里就不详细展开了

4, 安装 easy-sms,easy-sms 是安正超写的一个短信发送组件,利用这个组件,我们可以快速的实现短信发送功能。

 composer require "overtrue/easy-sms"     //新建配置文件     touch config/easysms.php

然后在 easysms.php 文件内 添加以下内容:

 <?php     return [         'timeout'=>5.0,        'default'=>[            // 网关调用策略,默认:顺序调用            'strategy' => /Overtrue/EasySms/Strategies/OrderStrategy::class,             // 默认可用的发送网关            'gateways' => [                'yunpian',            ],        ],        // 可用的网关配置        'gateways' => [            'errorlog' => [                'file' => '/tmp/easy-sms.log',            ],            'yunpian' => [                'api_key' => env('YUNPIAN_API_KEY'),            ],        ],      ];

然后创建一个 ServiceProvider

  php artisan make:provider EasySmsServiceProvider

修改文件

app/providers/EasySmsServiceProvider.php

<?php  namespace App/Providers;  use Illuminate/Support/ServiceProvider; use Overtrue/EasySms/EasySms;  class EasySmsServiceProvider extends ServiceProvider {     /**      * Bootstrap services.      *      * @return void      */     public function boot()     {         //     }      /**      * Register services.      *      * @return void      */     public function register()     {         $this->app->singleton(EasySms::class,function ($app){              return new EasySms(config('easysms'));          });          $this->app->alias(EasySms::class,'easysms');     } }

最后 打开config/app.php 在 providers 中增加

 App/Providers/EasySmsServiceProvider::class,

5,获取云片的API_KEY

在 .env中配置 YUNPIAN_API_KEY,注意下面需要替换为你自己的 key

6,控制器代码 获取验证码(将code 以及key存入缓存)

public function getVerificationCode($request)     {         if(FALSE === $this->validateApiRequest($request->all(),                 ['mobile' => 'required|regex:/^1[34578]/d{9}$/|unique:users'],[                     'mobile.required'=>'请输入手机号',                     'mobile.regex'=>'手机号格式不正确',                     'mobile.unique'=>'手机号已存在'                 ])){             return false;         }          $mobile = trim($request->get('mobile'));        $code = str_pad(random_int(1,9999),4,0,STR_PAD_LEFT);           try{              $easySms->send($mobile,                 ['content'=>"【UKNOW】您的验证码是{$code}。如非本人操作,请忽略本短信"]             );          }catch(/GuzzleHttp/Exception/ClientException $exception){              $response = $exception->getResponse();             $result =json_decode($response->getBody()->getContents(),true);             $this->setMsg($result['msg']?? '短信发送异常');             return false;         }          $key = 'verificationCode'.str_random(15);         $expiredAt = now()->addMinutes(1);         Cache::put($key,['mobile'=>$mobile,'code'=>$code],$expiredAt);          return [             'verification_key'=>$key,             'expiredAt'=>$expiredAt->toDateTimeString(),             'verification_code'=>$code             ];     }

7,对比验证码

public function userStore($mobile, $verification_key,$code,$password,$password_confirmation)     {          $params = [             'mobile'=>$mobile,             'verification_key'=>$verification_key,             'code'=>$code,             'password'=>$password,             'password_confirmation'=>$password_confirmation         ];         //参数判断         if (             FALSE === $this->validateApiRequest($params, [                 'mobile'  => 'required|regex:/^1[34578]/d{9}$/|unique:users',                 'code'    => 'required',                 'verification_key'=>'required',                 'password'     => 'required|min:6|confirmed',                 'password_confirmation' => 'required',             ], [                 'mobile.required' => '请输入手机号',                 'mobile.regex'    => '手机号格式不正确',                 'mobile.unique'   => '手机号已存在',                 'code.required'   => '请输入短信验证码',                 'password.required'    => '请输入密码',                 'password.min'         => '密码不得小于6位',                 'password.confirmed'   => '密码前后不一致',                 'password_confirmation.required'=>'请再次输入密码',                 'verification_key.required'=>'请输入短信验证码'             ])         ) {             return false;         }          $verifyData = Cache::get($verification_key);         if( !$verifyData){             $this->setMsg('验证码已失效');             return false;         }         if(!hash_equals($code,(string)$verifyData['code'])){             $this->setMsg('验证码错误');             return false;         }          Cache::forget($verification_key);         $user = User::create([             'mobile'=>$mobile,             'password'=>bcrypt($password)         ]);         if(!$user){             $this->setMsg('注册失败');             return false;         }         return true;     }

相关推荐:

thinkphp模板如何判断是手机微信支付还是微信扫码支付

PHP想要实现页面跳转功能具体怎么操作?(函数标签示例)

以上就是laravel框架下php手机短信验证码实现流程的详细内容,更多请关注清酒竹杯其它相关文章!

  • 相关标签:
  • 本文原创发布清酒竹杯 ,转载请注明出处,感谢您的尊重!
  • 发表评论

    电子邮件地址不会被公开。 必填项已用*标注