文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

php手机验证码实现的方法

2023-06-07 22:44

关注

这篇文章主要介绍“php手机验证码实现的方法”,在日常操作中,相信很多人在php手机验证码实现的方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”php手机验证码实现的方法”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

php手机验证码的实现方法:首先注册云片以及开发信息认证,并进行模板设置;然后在“easysms.php”文件内添加“'default'=>[]”等内容;接着获取云片的API_KEY;最后通过控制器代码获取验证码即可。

php手机验证码实现的方法

本文操作环境:Windows7系统、PHP7.1、Dell G3电脑。

PHP手机短信验证码实现流程详解

本人在自己博客(Laravel)的注册部分 使用手机号注册,需要发送短信验证码。

使用云片的短信服务提供商,当然具体短信服务提供商大家可以自由选择。

1、实现流程

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

2、实现思路图

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

<?phpnamespace App\Providers;use Illuminate\Support\ServiceProvider;use Overtrue\EasySms\EasySms;class EasySmsServiceProvider extends ServiceProvider{    public function boot()  {    //  }    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,

获取云片的API_KEY

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

控制器代码 获取验证码(将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      ];}

对比验证码

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;}

以上流程就是手机验证码基本步骤。

到此,关于“php手机验证码实现的方法”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯