이 글은 주로 PHP SMS 인증 코드의 구현 과정을 자세히 소개합니다. 관심 있는 친구들이 참고할 수 있습니다.
저는 제 블로그(Laravel) 등록 섹션에 휴대폰 번호를 사용합니다. SMS 인증 코드를 보내려면
Yunpian의 SMS 서비스 제공업체를 이용하세요. 물론 특정 SMS 서비스 제공업체를 자유롭게 선택할 수 있습니다.
1. 구현 과정
휴대폰 번호를 입력하고 클릭하여 인증 코드를 받으세요
정확한 SMS 인증 코드를 제출하면 등록이 완료됩니다
2. 구현 아이디어 맵
3. 클라우드 필름 등록, 개발 정보 인증 및 템플릿 설정 은 여기서 자세히 설명하지 않겠습니다
4. easy-sms, easy-sms 설치 는 An Zhengchao가 작성한 문자 메시지 전송 구성 요소입니다. 이 컴포넌트를 사용하면 문자 메시지 전송 기능을 빠르게 구현할 수 있습니다.
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/E asySmsService Provider.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를 열고 AppProvidersEasySmsServiceProvider::class를 추가하세요.
5. 클라우드 슬라이스의 API_KEY를 가져옵니다
.env에서 YUNPIAN_API_KEY를 구성하세요. 자신의 키
6 , 컨트롤러 코드가 인증 코드를 얻습니다(코드와 키를 캐시에 저장)
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; }
위 과정은 다음과 같습니다. 휴대폰 인증코드의 기본 단계입니다.
관련 권장 사항:
위 내용은 PHP 휴대폰 SMS 인증코드 구현 과정에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!