摘要:我們稍微封裝下代碼吧請您激活賬戶方法用于保存或更新字段方法用于判斷是否在小時之內(nèi)使用管理郵件在剛才的例子中,我們使用的是提供的方法來快速創(chuàng)建和發(fā)送郵件。
使用 Mailtrap 測試郵件功能
Mailtrap 提供了簡單的測試郵件的服務(wù),步驟如下:
登錄網(wǎng)站 Mailtrap
注冊用戶
注冊成功之后,會自動創(chuàng)建一個 demo,點進(jìn)去之后就可以看到配置信息
只需要把上面的信息配置到對應(yīng)的 .env 中即可:
MAIL_DRIVER=smtp MAIL_HOST=smtp.mailtrap.io MAIL_PORT=2525 MAIL_USERNAME=fc0ad24e593f34 MAIL_PASSWORD=aef271516bc810 MAIL_ENCRYPTION=null
這樣,我們在應(yīng)用里面發(fā)出去的郵件你都能在網(wǎng)站的 demo 中看到了。
用戶激活功能實現(xiàn) 用戶激活功能實現(xiàn)思路接下來談?wù)勔獙崿F(xiàn)的用戶激活功能的基本過程:
創(chuàng)建數(shù)據(jù)表,保存用戶激活信息;
提供激活選項給登錄其未激活的用戶;
用戶點擊激活之后,生成一個唯一的秘鑰,保存到數(shù)據(jù)庫;同時將秘鑰以參數(shù)形式附在超鏈接的后面顯示在用戶郵箱正文中;
用戶在郵箱中點擊超鏈接,返回網(wǎng)站;
網(wǎng)站根據(jù)參數(shù)是否匹配以及是否過期(24小時)來判斷用戶是否激活成功;
創(chuàng)建數(shù)據(jù)表因為激活的功能并不常用,將其多帶帶放置于一張表中:
$ php artisan make:model UserActivation -m
編輯字段:
/database/migrations/2017_04_21_071142_create_user_activations_table.php public function up() { Schema::create("user_activations", function (Blueprint $table) { $table->integer("user_id")->unsigned()->primary(); $table->string("token")->unique(); $table->boolean("active")->default(0); $table->timestamps(); $table->foreign("user_id") ->references("id") ->on("users") ->onDelete("cascade"); }); }
執(zhí)行:
$ php artisan migrate添加用戶表與用戶激活表的一對一關(guān)系
用戶表與用戶激活表為一對一關(guān)系:
/app/User.php public function activations() { return $this->hasOne(AppUserActivation::class); }
允許用戶激活表批量賦值:
/app/UserActivation.php protected $fillable= ["user_id","active","token"];添加激活選項
首先,讓登錄且未激活的用戶可以點擊「激活」按鈕:
/resources/views/layouts/nav.blade.php @if (Auth::check()) {{ Auth::user()->name }} 登出 @if (is_null(Auth::user()->activations) || Auth::user()->activations->active == 0) 發(fā)送激活郵件 @endif @else
路由指派該請求:
Route::get("/sendActivationMail","RegistrationController@send");
在實現(xiàn)具體的方法之前,我們先來介紹下如何快速發(fā)送郵件。
快速發(fā)送郵件先來看看 Laravel 提供的選項:
$message->from($address, $name = null); # 郵件的所有者 $message->sender($address, $name = null); # 郵件的實際傳輸人,若所有者與發(fā)送者為同一人,可省略 $message->replyTo($address, $name = null); # 作者建議回復(fù)的地址 $message->to($address, $name = null); # 收件人的地址 $message->cc($address, $name = null); # 收件人外,想讓其他知道該事的人的地址 $message->bcc($address, $name = null); # 不想讓 cc 的人看到你發(fā)送給了誰,那么就用 bcc $message->subject($subject); #主題 $message->priority($level); $message->attach($pathToFile, array $options = []);
注意,郵件的格式要遵守 RFC2822 規(guī)范,否則可能報錯。
from = "From:" mailbox-list CRLF sender = "Sender:" mailbox CRLF reply-to = "Reply-To:" address-list CRLF to = "To:" address-list CRLF cc = "Cc:" address-list CRLF bcc = "Bcc:" (address-list / [CFWS]) CRLF
我們舉一個簡單的例子:
public function send() { Mail::raw("test laravel blog email function",function ($message){ $from = ["From: [email protected]","fromman"]; $to = ["To: [email protected]","toman"]; $cc = ["Cc: [email protected]","ccman"]; $bcc = ["Bcc: [email protected]","bccman"]; $replyTo = ["Reply-To: [email protected]","replytoman"]; $sender = ["Sender: [email protected]","senderman"]; $subject = "Subject Subject"; $message->to($to) ->from($from) ->sender($sender) ->cc($cc) ->bcc($bcc) ->replyTo($replyTo) ->subject($subject); }); return redirect("/"); }
raw 方法發(fā)送純文本給對方。同時,我們在傳入的閉包函數(shù)中進(jìn)行配置。在本例子中,將會給 toman、ccman 和 bccman 三個人一人發(fā)送一封純文本郵件,因此,我們在 Mailtrap 中會收到三封:
因為 bcc 是密送,所以發(fā)送給 ccman 的郵件中看不到 bccman :
在上述的配置字段中, from 字段以預(yù)先定義好,這樣就不需要每次都填寫了。當(dāng)然,如果使用了 $message->from 方法,就會覆蓋配置。
/config/mail.php "from" => [ "address" => env("MAIL_FROM_ADDRESS", ""From: "[email protected]"), "name" => env("MAIL_FROM_NAME", "Zen"), ],激活功能實現(xiàn)
現(xiàn)在,我們實現(xiàn)可以發(fā)送激活郵件的功能了:
use AppUserActivation; public function send() { // 生成唯一 token $token = bcrypt(auth()->user()->email.time()); $user = auth()->user(); // 發(fā)送郵件 Mail::send("emails.activation", compact("user", "token"), function ($message) { $to = ["To: ".auth()->user()->email, auth()->user()->name]; $subject = "blog demo 請您激活賬戶"; $message->to($to) ->subject($subject); }); // 數(shù)據(jù)庫保存 token if ($user->activations){ $user->activations()->update(["token"=>$token]); } else { $user->activations()->save(new UserActivation([ "token" => $token ])); } // 發(fā)送并保存成功,跳轉(zhuǎn)到主頁 return redirect("/"); }
這次,我們使用的是 Mail::send 方法,該方法可以傳入視圖作為郵件內(nèi)容,同時第二個參數(shù)里傳入給視圖的數(shù)據(jù),接下來定義視圖:
/resources/views/emails/activation.blade.phpDocument 您好, {{ $user->name }} ! 請點擊下面鏈接完成注冊:
激活鏈接
用戶將會收到這樣的郵件:
點擊鏈接之后,會向網(wǎng)站發(fā)送請求,路由進(jìn)行指派:
Route::get("/activeAccount","RegistrationController@active");
最后,判斷該 token 是否過期或者是否匹配,匹配則跳轉(zhuǎn)到登錄頁面,否則跳轉(zhuǎn)到主頁。
use CarbonCarbon; public function active() { $token = request("verify"); $rs = UserActivation::where("token", $token) ->whereBetween("updated_at", [Carbon::now()->subDay(), Carbon::now()]); if ($rs->exists()) { $rs->update(["active"=>true]); return redirect("/login"); } return redirect("/"); }
功能已經(jīng)實現(xiàn)了。我們稍微封裝下代碼吧:
/app/Http/Controllers/RegistrationController.php public function send() { $token = bcrypt(auth()->user()->email.time()); $user = auth()->user(); Mail::send("emails.activation", compact("user", "token"), function ($message) { $to = ["To: ".auth()->user()->email, auth()->user()->name]; $subject = "blog demo 請您激活賬戶"; $message->to($to) ->subject($subject); }); $user->addActivationsData($token); return redirect("/"); } public function active() { $token = request("verify"); $rs = UserActivation::where("token", $token) ->notExpired(); if ($rs->exists()) { $rs->update(["active"=>true]); return redirect("/login"); } return redirect("/"); }
addActivationsData 方法用于保存或更新 $token 字段:
/app/User.php public function addActivationsData($token) { if ($this->activations) { $this->activations()->update(["token"=>$token]); } else { $this->activations()->save(new AppUserActivation([ "token" => $token ])); } }
notExpired 方法用于判斷 token 是否在 24 小時之內(nèi):
/app/UserActivation.php use CarbonCarbon; public function scopeNotExpired($query) { return $query->whereBetween("updated_at", [Carbon::now()->subDay(), Carbon::now()]); }使用 mailables 管理郵件
在剛才的例子中,我們使用的是 Mail 提供的方法來快速創(chuàng)建和發(fā)送郵件。實際上,Laravel 提供了管理不同類型郵件的方法。我們來快速了解下。
創(chuàng)建「歡迎」郵件類型首先,我們來創(chuàng)建一個用于歡迎新用戶的 mailables:
$ php artisan make:mail Welcome
首次使用時,會創(chuàng)建 app/Mail 目錄。接下來,我們就可以實現(xiàn)給用戶發(fā)送歡迎郵件的功能了。
首先,用戶注冊成功之后,發(fā)送一封歡迎郵件:
/app/Http/Controllers/RegistrationController.php use AppMailWelcome; public function store() { ... auth()->login($user); Mail::to($user)->send(new Welcome); return redirect()->home(); }
之前我們通過閉包的方式傳遞 from 、to 等字段,實際上,也可以直接將 $user 實例直接傳遞給 to,這樣會自動去識別 name 和 from 字段。然后,send 方法傳入 mailables 類即可。
配置 mailables如果使用 to($user) 可能會報錯,因為不符合我們之前說的 RFC2822 規(guī)范。
接下來,發(fā)送郵件的主要功能都可以在定義的 Welcome 類中實現(xiàn)了。
可以定義郵件的 blade 視圖:
/app/Mail/Welcome.php public function build() { return $this->view("emails.welcome"); }
顯示結(jié)果為:
也可以定義純文本視圖:
/app/Mail/Welcome.php public function build() { return $this->text("emails.welcome"); }
對應(yīng)的視圖文件如下:
/resources/views/emails/welcome.blade.phpDocument {{$name}}, 歡迎成為 Blog Demo 的會員
可以配置郵件的各種信息,跟之前的方式類似:
public function build() { $from = ["From: [email protected]","fromman"]; $to = ["To: [email protected]","toman"]; $subject = "Subject Subject"; return $this->text("emails.welcome") ->to($to) ->from($from) ->subject($subject); }
可以傳遞變量給視圖,第一種是直接在 view 里面?zhèn)鬟f(也可以使用 with):
/app/Mail/Welcome.php public function build() { $from = ["From: [email protected]","fromman"]; $to = ["To: [email protected]","toman"]; $subject = "Subject Subject"; $user = auth()->user(); return $this->view("emails.welcome",compact("user")) ->to($to) ->from($from) ->subject($subject); } /resources/views/emails/welcome.blade.php{{$user->name }}, 歡迎成為 Blog Demo 的會員
另外一種方法是,在 Welcome 類中定義屬性類型為「公共的」。這樣該屬性就會自動傳遞給視圖:
/app/Http/Controllers/RegistrationController.php Mail::send(new Welcome); /app/Mail/Welcome.php public $user; public function __construct(User $user) { $this->user = $user; }
最后,我們還可以使用 Markdown 的語法來寫郵件:
$ php artisan make:mail MDWelcome --markdown="emails.md-welcome"
創(chuàng)建使用使用 --markdown 參數(shù)來生成對應(yīng)的視圖即可。具體使用方法可以查看文檔。
參考資料:
RFC2822 中文文檔
Laravel 的 郵件發(fā)送功能 | Laravel 5.4 中文文檔
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/22824.html
摘要:本節(jié)內(nèi)容比較簡單,之前我們使用方法來進(jìn)行字段驗證,這樣做有一個不好的地方就是,如果你要在很多地方使用同樣的驗證,就需要重復(fù)編寫代碼。因此,提供另外一種方式來進(jìn)行字段驗證,即請求類。 本節(jié)內(nèi)容比較簡單,之前我們使用 validator 方法來進(jìn)行字段驗證,這樣做有一個不好的地方就是,如果你要在很多地方使用同樣的驗證,就需要重復(fù)編寫代碼。因此,Laravel 提供另外一種方式來進(jìn)行字段驗證...
摘要:本節(jié)將實現(xiàn)文章評論與用戶關(guān)聯(lián)的功能。關(guān)系定義首先修改與表,增加字段增加全部回滾并重新執(zhí)行遷移添加用戶表與文章表評論表的一對多關(guān)系添加文章評論表與用戶表的多對一關(guān)系同時,評論表的字段增加。同時,我們還自定義了返回的錯誤信息。 本節(jié)將實現(xiàn)文章、評論與用戶關(guān)聯(lián)的功能。 關(guān)系定義 首先修改 posts 與 comments 表,增加 user_id 字段 /database/migratio...
摘要:將上述的一系列查詢進(jìn)行封裝模型到了這一步,我們基本上實現(xiàn)了文章歸檔的功能。但是有一個問題,文章歸檔實際上包括在通用視圖中,這就意味著,網(wǎng)站的所有請求都需要返回,否則就會報錯。數(shù)據(jù)庫之?dāng)?shù)據(jù)庫請求構(gòu)建器中文文檔的視圖功能中文文檔 首先,要實現(xiàn)的是按照日期來統(tǒng)計文章,原始的 SQL 如下: select year(created_at) year, monthname(c...
摘要:同時,傳入?yún)?shù),即已存在的查詢。因此,更為常見的做法是在控制器中處理路由請求。 這一節(jié),我們進(jìn)一步完善上一節(jié)創(chuàng)建的任務(wù)列表。主要知識點: Eloquent Model 控制器 路由模型綁定 Eloquent Model 新增遷移 首先,我們?yōu)閿?shù)據(jù)庫表 tasks 新增一個字段 completed,用來表示任務(wù)是否完成: $ php artisan make:migration ad...
摘要:它的目的是提供正確的方式進(jìn)行頁面交互測試,所以可以使用去點擊按鈕或者鏈接填寫表單甚至拖放。此外,提到測試運行比更快。此次因底層架構(gòu)改變較大而重命名。這個功能受到的啟發(fā),能夠?qū)⒃睾喕癁榭芍赜脜^(qū)域。 showImg(https://segmentfault.com/img/remote/1460000008212617); 轉(zhuǎn)自 Laravel 社區(qū):https://laravel-ch...
閱讀 2175·2021-11-11 16:55
閱讀 1697·2019-08-30 15:54
閱讀 2827·2019-08-30 15:53
閱讀 2223·2019-08-30 15:44
閱讀 1159·2019-08-30 15:43
閱讀 974·2019-08-30 11:22
閱讀 1954·2019-08-29 17:20
閱讀 1575·2019-08-29 16:56