本文實例講述了laravel框架郵箱認(rèn)證實現(xiàn)方法。分享給大家供大家參考,具體如下:
修改 User 模型,將 Laravel 自帶的郵箱認(rèn)證功能集成到我們的程序中
?php
namespace App\Models;
use Illuminate\Notifications\Notifiable;
use Illuminate\Auth\MustVerifyEmail as MustVerifyEmailTrait;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Contracts\Auth\MustVerifyEmail as MustVerifyEmailContract;
class User extends Authenticatable implements MustVerifyEmailContract
{
use Notifiable, MustVerifyEmailTrait;
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name', 'email', 'password',
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password', 'remember_token',
];
/**
* The attributes that should be cast to native types.
*
* @var array
*/
protected $casts = [
'email_verified_at' => 'datetime',
];
}
代碼詳解:
加載使用 MustVerifyEmail
trait,打開 vendor/laravel/framework/src/Illuminate/Auth/MustVerifyEmail.php
文件,可以看到以下三個方法:
hasVerifiedEmail()
檢測用戶 Email 是否已認(rèn)證;
markEmailAsVerified()
將用戶標(biāo)示為已認(rèn)證;
sendEmailVerificationNotification()
發(fā)送 Email 認(rèn)證的消息通知,觸發(fā)郵件的發(fā)送。
得益于 PHP 的 trait 功能,User 模型在 use
以后,即可使用以上三個方法。
可以打開 vendor/laravel/framework/src/Illuminate/Contracts/Auth/MustVerifyEmail.php
,可以看到此文件為 PHP 的接口類,繼承此類將確保 User 遵守契約,擁有上面提到的三個方法。
如果我們使用了 Laravel 自帶的 RegisterController
,控制器通過加載 Illuminate\Foundation\Auth\RegistersUsers
trait 來引入框架的注冊功能,此時我們打開此 trait 來翻閱源碼并定位到 register(Request $request)
方法:
此方法處理了用戶提交表單后的邏輯,我們把重點放在 event(new Registered($user = $this->create($request->all())));
,這里使用了 Laravel 的事件系統(tǒng),觸發(fā)了 Registered
事件。
打開 app/Providers/EventServiceProvider.php
文件,此文件的 $listen
屬性里我們可以看到注冊了Registered
事件的監(jiān)聽器:
打開 SendEmailVerificationNotification
類,閱讀其源碼:
vendor/laravel/framework/src/Illuminate/Auth/Listeners/SendEmailVerificationNotification.php
可以看出 Laravel 默認(rèn)已經(jīng)為我們設(shè)置了郵件發(fā)送的邏輯
強(qiáng)制用戶認(rèn)證
我們希望用戶認(rèn)證郵箱后,才能使用網(wǎng)站。
我們將使用 Laravel 中間件 來過濾用戶的所有請求,如果用戶未認(rèn)證的話,就跳轉(zhuǎn)到郵件認(rèn)證提醒的頁面中
可以使用以下命令來新建一個中間件:
php artisan make:middleware EnsureEmailIsVerified
打開生成的文件并代入以下內(nèi)容:
app/Http/Middleware/EnsureEmailIsVerified.php
?php
namespace App\Http\Middleware;
use Closure;
class EnsureEmailIsVerified
{
public function handle($request, Closure $next)
{
// 三個判斷:
// 1. 如果用戶已經(jīng)登錄
// 2. 并且還未認(rèn)證 Email
// 3. 并且訪問的不是 email 驗證相關(guān) URL 或者退出的 URL。
if ($request->user()
! $request->user()->hasVerifiedEmail()
! $request->is('email/*', 'logout')) {
// 根據(jù)客戶端返回對應(yīng)的內(nèi)容
return $request->expectsJson()
? abort(403, 'Your email address is not verified.')
: redirect()->route('verification.notice');
}
return $next($request);
}
}
接下來注冊中間件,注冊的時機(jī)確保在 StartSession
后面即可:
app/Http/Kernel.php
此時如果我們沒有認(rèn)證郵箱就會看到認(rèn)證提醒,并且除了我們上面代碼中設(shè)置的 URL 外都會進(jìn)入此頁面:
內(nèi)置郵箱認(rèn)證還有個小功能,當(dāng)你點擊點擊多次『重新發(fā)送 Email』后,系統(tǒng)會自動做限額處理,可以有效防止用戶消耗太多資源。你可以在 VerificationController
中配置相應(yīng)的信息:
更多關(guān)于Laravel相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進(jìn)階教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家基于Laravel框架的PHP程序設(shè)計有所幫助。
您可能感興趣的文章:- Laravel 默認(rèn)郵箱登錄改成用戶名登錄的實現(xiàn)方法
- laravel5.4利用163郵箱發(fā)送郵件的步驟詳解
- 在Laravel框架里實現(xiàn)發(fā)送郵件實例(郵箱驗證)
- Laravel 5框架學(xué)習(xí)之用戶認(rèn)證
- 詳解Laravel5.6 Passport實現(xiàn)Api接口認(rèn)證
- Laravel5.5中利用Passport實現(xiàn)Auth認(rèn)證的方法
- Laravel實現(xiàn)用戶多字段認(rèn)證的解決方法
- Laravel認(rèn)證原理以及完全自定義認(rèn)證詳解
- Laravel多用戶認(rèn)證系統(tǒng)示例詳解
- 解決Laravel5.2 Auth認(rèn)證退出失效的問題
- laravel實現(xiàn)Auth認(rèn)證,登錄、注冊后的頁面回跳方法