好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Laravel實現短信注冊的示例代碼

Laravel實現短信注冊的示例代碼

熱門標簽:寶安400電話辦理 高識別電銷機器人 電銷機器人-快迭智能 哈爾濱400電話辦理到易號網 沈陽人工智能電銷機器人公司 合肥外呼系統app h5 地圖標注 拉薩打電話機器人 智能外呼電銷系統

正在公司做一個商城項目,由于只有一個后臺,所以注冊用短信注冊也就輪到我來做的。剛剛開始,我內心還是有點虛的,還好有 Laravel-china 社區的 summer 大神,寫的書。在里面參考了它的寫法和思路,并且用了 easy-sms 包,這才用了半個下午的時間,順利的做出來了,晚上趕緊和大家分享一波了。

1、確定短信運營商

我看到大佬都是用的云片,我也就毫不猶豫的大力推薦公司用這個短信平臺了,不過其他的也可以咯。

首先自己注冊一個帳號,然后找到這個

 

點擊開始接入,完成新手引導過程。

 

第二部的簽名和模板必須填寫,類似我下面填寫的這樣

 

值得注意的是這個模板必須和你到時候用 easy-sms 包的時候,設定的短信內容必須和這個一模一樣,不然會報錯的。

還有就是記得一定得拿到APIKEY。到時候,在env里進行配置。

# 云片
YUNPIAN_API_KEY=9c60bdd**********

2、安裝 easy-sms

利用這個包,可以快速的實現短信發送功能。

composer require "overtrue/easy-sms"

由于該組件還沒有 Laravel 的 ServiceProvider ,為了方便使用,我們可以自己封裝一下。

首先在 config 目錄中增加 easysms.php 文件

config/easysms.php 填寫如下內容。

?php
return [
 // HTTP 請求的超時時間(秒)
 '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

?php

namespace App\Providers;

use Overtrue\EasySms\EasySms;
use Illuminate\Support\ServiceProvider;

class EasySmsServiceProvider extends ServiceProvider
{
 /**
  * Bootstrap the application services.
  *
  * @return void
  */
 public function boot()
 {
  //
 }

 /**
  * Register the application 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.phpproviders 里增加剛剛創建的服務寫進去,App\Providers\EasySmsServiceProvider::class,

App\Providers\AppServiceProvider::class,
App\Providers\AuthServiceProvider::class,
// App\Providers\BroadcastServiceProvider::class,
App\Providers\EventServiceProvider::class,
App\Providers\RouteServiceProvider::class,

App\Providers\EasySmsServiceProvider::class, //easy-sms

3、創建路由和對應的控制器

首先創建路由,我們需要一個ajax請求短信驗證碼的方法,和一個進行確認注冊的邏輯方法,如下:

Route::group(['prefix' => 'verificationCodes', 'as' => 'verificationCodes.'], function() {
  Route::post('register', 'VerificationCodesController@register')->name('register');
  Route::get('ajaxregister', 'VerificationCodesController@ajaxregister')->name('ajaxregister');
 });

路由創建好了,我們用命令生成controller了

php artisan make:controller Home\VerificationCodesController

再直接在里面寫 registerajaxregister 方法了

代碼邏輯

修改文件

app/Home/VerificationCodesController.php

?php
.
.
.
use Overtrue\EasySms\EasySms;
use App\Models\System\User;
class VerificationCodesController extends Controller
{
 // 這里驗證就不寫了。
 public function ajaxregister(VerificationCodeRequest $request, EasySms $easySms)
 {
  //獲取前端ajax傳過來的手機號
  $phone = $request->phone;
  
  // 生成4位隨機數,左側補0
  $code = str_pad(random_int(1, 9999), 4, 0, STR_PAD_LEFT);
  
  try {
   $result = $easySms->send($mobile, [
    'content' => "【安拾商城】您的驗證碼是{$code}。如非本人操作,請忽略本短信"
   ]);
  } catch (Overtrue\EasySms\Exceptions\NoGatewayAvailableException $exception) {
   $response = $exception->getExceptions();
   return response()->json($response);
  }
  
  //生成一個不重復的key 用來搭配緩存cache判斷是否過期
  $key = 'verificationCode_' . str_random(15);
  $expiredAt = now()->addMinutes(10);
  
  // 緩存驗證碼 10 分鐘過期。
  \Cache::put($key, ['mobile' => $mobile, 'code'=> $code], $expiredAt);
  
  return response()->json([
   'key' => $key,
   'expired_at' => $expiredAt->toDateTimeString(),
  ], 201);
 }

這樣,用戶就能收到短信,并且前端應該保存這個 key ,提交注冊表單的時候傳遞給后臺,判斷是否已經過期。下面就是判斷是否過期,驗證碼是否錯誤。

public function register(VerificationCodeRequest $request)
{
 //獲取剛剛緩存的驗證碼和key
 $verifyData = \Cache::get($request->verification_key);
 
 //如果數據不存在,說明驗證碼已經失效。
 if(!$verifyData) {
  return response()->json(['status' =>0, 'message'=> '短信驗證碼已失效'], 422);
 }
 
 // 檢驗前端傳過來的驗證碼是否和緩存中的一致
 if (!hash_equals($verifyData['code'], $request->verification_code) {
  return redirect()->back()->with('warning', '短信驗證碼錯誤');
 }
 
 $user = User::create([
  'mobile' => $verifyData['mobile'],
  'password' => bcrypt($request->password),
 ]);

 // 清除驗證碼緩存
 \Cache::forget($request->verification_key);

 return redirect()->route('login')->with('success', '注冊成功!');
 
}

上面的 hash_equals 是可防止時序攻擊的字符串比較的~

以上就是我整個的過程。

您可能感興趣的文章:
  • Laravel中使用阿里云OSS Composer包分享
  • Laravel框架中實現使用阿里云ACE緩存服務
  • Laravel中擴展Memcached緩存驅動實現使用阿里云OCS緩存
  • 阿里對象存儲OSS在laravel框架中的使用方法
  • Laravel框架實現發送短信驗證功能代碼
  • 使用 laravel sms 構建短信驗證碼發送校驗功能
  • laravel中短信發送驗證碼的實現方法
  • 用Laravel Sms實現laravel短信驗證碼的發送的實現
  • 在 Laravel 中 “規范” 的開發短信驗證碼發送功能
  • laravel框架使用阿里云短信發送消息操作示例

標簽:威海 梅州 張家口 山東 成都 泰州 林芝 巴中

巨人網絡通訊聲明:本文標題《Laravel實現短信注冊的示例代碼》,本文關鍵詞  Laravel,實現,短信,注冊,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Laravel實現短信注冊的示例代碼》相關的同類信息!
  • 本頁收集關于Laravel實現短信注冊的示例代碼的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 91丨九色丨白浆秘?小青龙| h激情小说| 帝少宠妻七天七夜顶点小说| 男同桌上课狂揉我下边好软好多水 | 少妇成熟A片无码专区九色| 黄页网站在线看| 91久久精品国自产拍综合五区 | 山村乱肉合集乱500篇| 九九热亚洲精品综合视频| 小柔好湿?好紧?好滑| 欧美真人做爰在线观看| 女人18毛片免费视频播放| 嗯啊羞羞视频| 高校教师在线| 99久热视频在线精品| 情欲情欲欲超市全文无删减| 宝贝你的好小好紧好爽| 成人欧美一区二区三区白人 | 美乳弹出来RION宇都宫紫| 清纯美女露脸果贷自拍| 奇优影院手机免费版在线| 寡妇野外啪啪一区二区| 97久久超碰国产精品最新_亚洲中字精品 | 国产AV无遮挡喷水喷白浆| 国产?刺激?高潮?AV| 91自啪区| 西欧free性video巴西| 免费看黄大全| 欧美成人无码一二区免费网站黄 | 麻豆乱码国产一区二区三区四区| 办公室可不可以干湿你的床垫| 嗯啊嗯哼| 日本少妇高潮XXXXⅩOOO| 久久免费观看国产精品动漫| jiZZjiZZji?ZZ亚洲熟女| 三级乡下寡妇| hugeboobspics大胸大乳japanese| 特级毛片绝黄A片免费播冫| 欧美性大作XXXX久久久久3D| r逼| 乱肥老妇|