各类知识收集,PHP技术分享与解决方案各类知识收集,PHP技术分享与解决方案各类知识收集,PHP技术分享与解决方案

Str Tom,为分享PHP技术和解决方案,贡献一份自己的力量!
收藏本站(不迷路),每天更新好文章!
当前位置:首页 > CMS教程 > PHP

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

管理员 2023-09-05
PHP
143

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手机短信验证码实现流程所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。

内容备注

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

相关推荐

扫码关注

qrcode

QQ交谈

回顶部