PHP手機(jī)短信驗(yàn)證碼實(shí)現(xiàn)流程詳解
本人在自己博客(Laravel)的注冊(cè)部分 使用手機(jī)號(hào)注冊(cè),需要發(fā)送短信驗(yàn)證碼。
使用云片的短信服務(wù)提供商,當(dāng)然具體短信服務(wù)提供商大家可以自由選擇。
1、實(shí)現(xiàn)流程
輸入手機(jī)號(hào),點(diǎn)擊獲取驗(yàn)證碼
提交正確的短信驗(yàn)證碼后,注冊(cè)完成
2、實(shí)現(xiàn)思路圖
3、注冊(cè) 云片,以及開發(fā)信息認(rèn)證,模板設(shè)置,這里就不詳細(xì)展開了
4、安裝 easy-sms,easy-sms 是安正超寫的一個(gè)短信發(fā)送組件,利用這個(gè)組件,我們可以快速的實(shí)現(xiàn)短信發(fā)送功能。
composer require "overtrue/easy-sms" //新建配置文件 touch config/easysms.php
然后在 easysms.php 文件內(nèi) 添加以下內(nèi)容:
<?php return [ 'timeout'=>5.0, 'default'=>[ // 網(wǎng)關(guān)調(diào)用策略,默認(rèn):順序調(diào)用 'strategy' => \Overtrue\EasySms\Strategies\OrderStrategy::class, // 默認(rèn)可用的發(fā)送網(wǎng)關(guān) 'gateways' => [ 'yunpian', ], ], // 可用的網(wǎng)關(guān)配置 'gateways' => [ 'errorlog' => [ 'file' => '/tmp/easy-sms.log', ], 'yunpian' => [ 'api_key' => env('YUNPIAN_API_KEY'), ], ], ];
然后創(chuàng)建一個(gè) 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、控制器代碼 獲取驗(yàn)證碼(將code 以及key存入緩存)
public function getVerificationCode($request) { if(FALSE === $this->validateApiRequest($request->all(), ['mobile' => 'required|regex:/^1[34578]\d{9}$/|unique:users'],[ 'mobile.required'=>'請(qǐng)輸入手機(jī)號(hào)', 'mobile.regex'=>'手機(jī)號(hào)格式不正確', 'mobile.unique'=>'手機(jī)號(hào)已存在' ])){ 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】您的驗(yàn)證碼是{$code}。如非本人操作,請(qǐng)忽略本短信"] ); }catch(\GuzzleHttp\Exception\ClientException $exception){ $response = $exception->getResponse(); $result =json_decode($response->getBody()->getContents(),true); $this->setMsg($result['msg']?? '短信發(fā)送異常'); 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、對(duì)比驗(yàn)證碼
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 ]; //參數(shù)判斷 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' => '請(qǐng)輸入手機(jī)號(hào)', 'mobile.regex' => '手機(jī)號(hào)格式不正確', 'mobile.unique' => '手機(jī)號(hào)已存在', 'code.required' => '請(qǐng)輸入短信驗(yàn)證碼', 'password.required' => '請(qǐng)輸入密碼', 'password.min' => '密碼不得小于6位', 'password.confirmed' => '密碼前后不一致', 'password_confirmation.required'=>'請(qǐng)?jiān)俅屋斎朊艽a', 'verification_key.required'=>'請(qǐng)輸入短信驗(yàn)證碼' ]) ) { return false; } $verifyData = Cache::get($verification_key); if( !$verifyData){ $this->setMsg('驗(yàn)證碼已失效'); return false; } if(!hash_equals($code,(string)$verifyData['code'])){ $this->setMsg('驗(yàn)證碼錯(cuò)誤'); return false; } Cache::forget($verification_key); $user = User::create([ 'mobile'=>$mobile, 'password'=>bcrypt($password) ]); if(!$user){ $this->setMsg('注冊(cè)失敗'); return false; } return true; }
以上流程就是手機(jī)驗(yàn)證碼基本步驟。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
基于thinkPHP框架實(shí)現(xiàn)留言板的方法
這篇文章主要介紹了基于thinkPHP框架實(shí)現(xiàn)留言板的方法,簡(jiǎn)單分析了thinkPHP框架實(shí)現(xiàn)留言板的流程及控制器與模型的相關(guān)核心代碼,需要的朋友可以參考下2016-10-10Laravel框架實(shí)現(xiàn)簡(jiǎn)單的學(xué)生信息管理平臺(tái)案例【附源碼下載】
這篇文章主要介紹了Laravel框架實(shí)現(xiàn)簡(jiǎn)單的學(xué)生信息管理平臺(tái),結(jié)合具體案例形式較為詳細(xì)的分析了基于Laravel框架的學(xué)生信息管理平臺(tái)路由與控制器相關(guān)操作技巧,并附帶完整源碼供讀者下載參考,需要的朋友可以參考下2019-05-05Yii2框架制作RESTful風(fēng)格的API快速入門教程
Yii提供了一整套用來簡(jiǎn)化實(shí)現(xiàn)RESTful風(fēng)格的WebService服務(wù)的API。這篇文章主要介紹了Yii2框架制作RESTful風(fēng)格的API快速入門教程的相關(guān)資料,需要的朋友可以參考下2016-11-11laravel自定義分頁(yè)的實(shí)現(xiàn)案例offset()和limit()
今天小編就為大家分享一篇laravel自定義分頁(yè)的實(shí)現(xiàn)案例offset()和limit(),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-10-10PHP安裝threads多線程擴(kuò)展基礎(chǔ)教程
php5.3或以上,且為線程安全版本。apache和php使用的編譯器必須一致,通過phpinfo()查看Thread Safety為enabled則為線程安全版,通過phpinfo()查看Compiler項(xiàng)可以知道使用的編譯器,本文給大家介紹PHP安裝threads多線程擴(kuò)展基礎(chǔ)教程,需要的朋友參考下2015-11-11Yii框架視圖、視圖布局、視圖數(shù)據(jù)塊操作示例
這篇文章主要介紹了Yii框架視圖、視圖布局、視圖數(shù)據(jù)塊操作,結(jié)合實(shí)例形式分析了Yii框架相關(guān)的視圖、布局、控制器及數(shù)據(jù)相關(guān)操作技巧,需要的朋友可以參考下2019-10-10簡(jiǎn)單談?wù)凱HP面向?qū)ο笾畼?biāo)識(shí)對(duì)象
下面小編就為大家?guī)硪黄?jiǎn)單談?wù)凱HP面向?qū)ο笾畼?biāo)識(shí)對(duì)象。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-06-06復(fù)現(xiàn)WordPress?xmlrpc.php漏洞和SSRF的詳細(xì)步驟
這篇文章主要介紹了復(fù)現(xiàn)WordPress?xmlrpc.php漏洞和SSRF的相關(guān)資料,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-04-04