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

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

内容导读

收集整理的这篇技术教程文章主要介绍了laravel框架下php手机短信验证码实现流程,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3911字,纯文字阅读大概需要6分钟

内容图文

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

1,实现流程

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

2,实现思路图

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

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

 composer require "overtrue/easy-sms"

//新建配置文件

touch config/easysms.php

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

 <?php
 return [


 'timeout'=>5.0,


 'default'=>[




 // 网关调用策略,默认:顺序调用




 'strategy' => OvertrueEasySmsStrategiesOrderStrategy::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

<?phpnamespace AppProviders;use IlluminateSupportServiceProvider;use OvertrueEasySmsEasySms;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 中增加

 AppProvidersEasySmsServiceProvider::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(GuzzleHttpExceptionClientException $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手机短信验证码实现流程的详细内容,更多请关注Gxl网其它相关文章!

内容总结

以上是为您收集整理的laravel框架下php手机短信验证码实现流程全部内容,希望文章能够帮你解决laravel框架下php手机短信验证码实现流程所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。

内容备注

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。


本文关键词:

联系我们

在线咨询:点击这里给我发消息

邮件:w420220301@qq.com