溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

使用Laravel怎么實(shí)現(xiàn)驗(yàn)證碼認(rèn)證

發(fā)布時(shí)間:2021-07-19 14:49:10 來(lái)源:億速云 閱讀:270 作者:Leah 欄目:開發(fā)技術(shù)

使用Laravel怎么實(shí)現(xiàn)驗(yàn)證碼認(rèn)證,相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。

注冊(cè)驗(yàn)證碼

1. composer 安裝驗(yàn)證碼

composer require "mews/captcha:~3.0"

2. 運(yùn)行以下命令生成配置文件 config/captcha.php

php artisan vendor:publish --provider='Mews.aptcha.aptchaServiceProvider'

3. 前端展示驗(yàn)證碼

<img class="thumbnail captcha mt-3 mb-2" src="{{ captcha_src('flat') }}" onclick="this.src='/captcha/flat?'+Math.random()" title="點(diǎn)擊圖片重新獲取驗(yàn)證碼">

4. 后端驗(yàn)證(該擴(kuò)展包是為 Laravel 定制的擴(kuò)展包,完全兼容 laravel 注冊(cè)功能,驗(yàn)證非常方便)只需要在 app/Http/Controllers/Auth/RegisterController.php 中的驗(yàn)證規(guī)則中加入如下代碼:

 'captcha' => ['required', 'captcha'],

郵箱認(rèn)證

laravel 自帶郵箱認(rèn)證

laravel 自帶的郵箱認(rèn)證文件位于 vendor/laravel/framework/src/Illuminate/Auth/MustVerifyEmail.php ,因?yàn)榇宋募捎?trait 聲明,因此我們快速的將內(nèi)容通過(guò) use 集成到用戶的模型中,并進(jìn)行調(diào)用,如下:

  namespace App\Models;
  use Illuminate\Foundation\Auth\User as Authenticatable;
  use Illuminate\Notifications\Notifiable;
  use Illuminate\Auth\MustVerifyEmail as MustVerifyEmailTrait;
  class User extends Authenticatable {
    use Notifiable, MustVerifyEmailTrait;

為了代碼的規(guī)范,我們可以接入 larave 自帶的郵箱驗(yàn)證接口 Illuminate\Contracts\Auth\MustVerifyEmail,規(guī)定模型必須擁有相關(guān)的方法,具體方法如下(方法在 MustVerifyEmailTrait 中已經(jīng)定義好,直接調(diào)用既可):

  • hasVerifiedEmail() 檢測(cè)用戶 Email 是否已認(rèn)證;

  • markEmailAsVerified() 將用戶標(biāo)示為已認(rèn)證;

  • sendEmailVerificationNotification() 發(fā)送 Email 認(rèn)證的消息通知,觸發(fā)郵件的發(fā)送;

  • getEmailForVerification() 獲取發(fā)送郵件地址,提供這個(gè)接口允許你自定義郵箱字段。

發(fā)送郵件

我們使用了 Laravel 自帶的 RegisterController ,控制器通過(guò)加載 Illuminate.oundation.uth.egistersUsers trait 來(lái)引入框架的注冊(cè)功能,此時(shí)我們打開此 trait 來(lái)翻閱源碼并定位到 register(Request $request) 方法:

public function register(Request $request) { 
// 檢驗(yàn)用戶提交的數(shù)據(jù)是否有誤 
$this->validator($request->all())->validate(); 
// 創(chuàng)建用戶同時(shí)觸發(fā)用戶注冊(cè)成功的事件,并將用戶傳參 
event(new Registered($user = $this->create($request->all()))); 
// 登錄用戶 
$this->guard()->login($user); 
// 調(diào)用鉤子方法`registered()`
return $this->registered($request, $user) ?: redirect($this->redirectPath()); 
}

此方法處理了用戶提交表單后的邏輯,我們把重點(diǎn)放在 event(new Registered($user = $this->create($request->all())));,這里使用了 Laravel 的事件系統(tǒng),觸發(fā)了 Registered 事件。

打開 app/Providers/EventServiceProvider.php 文件,此文件的 $listen 屬性里我們可以看到注冊(cè)了 Registered 事件的監(jiān)聽器:

protected $listen = [ 
  Registered::class => [ SendEmailVerificationNotification::class, ], 
];

打開 SendEmailVerificationNotification 類,閱讀其源碼:vendor/laravel/framework/src/Illuminate/Auth/Listeners/SendEmailVerificationNotification.php

<?php 
namespace Illuminate\Auth\Listeners;

use Illuminate\Auth\Events\Registered;
use Illuminate\Contracts\Auth\MustVerifyEmail;

class SendEmailVerificationNotification
{
  /**
   * 處理事件
   *
   * @param \Illuminate\Auth\Events\Registered $event
   * @return void
   */
  public function handle(Registered $event)
  {
    // 如果 user 是繼承于 MustVerifyEmail 并且還未激活的話
    if ($event->user instanceof MustVerifyEmail && ! $event->user->hasVerifiedEmail()) {
      // 發(fā)送郵件認(rèn)證消息通知(認(rèn)證郵件)
      $event->user->sendEmailVerificationNotification();
    }
  }
}

可以看出 Laravel 默認(rèn)已經(jīng)為我們?cè)O(shè)置了郵件發(fā)送的邏輯,接下來(lái)我們來(lái)測(cè)試一下。

測(cè)試郵件

測(cè)試之前,我們先設(shè)置下郵件發(fā)送到 log 中,以便后面的測(cè)試:

修改環(huán)境設(shè)置文件.env

MAIL_DRIVER=log

郵件一般發(fā)在 storage/logs 目錄下的日志文件中

看完上述內(nèi)容,你們掌握使用Laravel怎么實(shí)現(xiàn)驗(yàn)證碼認(rèn)證的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI