laravel的用戶修改密碼與綁定郵箱的詳細(xì)操作
目錄
- 一、修改密碼
- 1.1 創(chuàng)建修改密碼控制器
- 1.2 創(chuàng)建修改密碼路由
- 1.3 測試效果
- 二、綁定郵箱
- 2.1 綁定郵箱控制器
- 2.2 創(chuàng)建對(duì)應(yīng)路由
- 2.3 創(chuàng)建發(fā)送郵件的類
- 2.4 測試效果
一、修改密碼
1.1 創(chuàng)建修改密碼控制器
運(yùn)行命令php artisan make:controller Auth/PasswordController
寫入修改密碼方法:
/** * 修改密碼 */ public function updatePassword(Request $request) { $request->validate([ 'old_password' => 'required|min:6|max:16', 'password' => 'required|min:6|max:16|confirmed', ], [ 'old_password.required' => '舊密碼不能為空', 'old_password.min' => '舊密碼最少6個(gè)字符', 'old_password.max' => '舊密碼最多16個(gè)字符', ]); // 舊密碼 $old_password = $request->input('old_password'); // 用戶實(shí)例 $user = auth('api')->user(); // 驗(yàn)證舊密碼是否正確 if (!password_verify($old_password, $user->password)) { return $this->response->errorBadRequest('舊密碼不正確'); } // 更新用戶密碼 $user->password = bcrypt($request->input('password')); $user->save(); return $this->response->noContent(); }
1.2 創(chuàng)建修改密碼路由
// 修改密碼 $api->post('password/update', [PasswordController::class, 'updatePassword']);
1.3 測試效果
二、綁定郵箱
2.1 綁定郵箱控制器
運(yùn)行命令php artisan make:controller Auth/BindController
創(chuàng)建綁定郵箱的控制器:
寫入發(fā)送郵箱驗(yàn)證碼和更新郵箱的處理函數(shù):
<?php namespace AppHttpControllersAuth; use AppHttpControllersBaseController; use AppMailSendEmailCode; use IlluminateHttpRequest; use IlluminateSupportFacadesMail; class BindController extends BaseController { /** * 獲取郵件的驗(yàn)證碼 */ public function emailCode(Request $request) { $request->validate([ 'email' => 'required|email' ]); // 發(fā)送驗(yàn)證碼到郵件 Mail::to($request->input('email'))->queue(new SendEmailCode($request->input('email'))); return $this->response->noContent(); } /** * 更新郵箱 */ public function updateEmail(Request $request) { $request->validate([ 'email' => 'required|email', 'code' => 'required' ], [ 'code.required' => "驗(yàn)證碼不能為空", ]); // 驗(yàn)證code是否正確 if (cache($request->input('email')) != $request->input('code')) { return $this->response->errorBadRequest('驗(yàn)證碼或郵箱錯(cuò)誤!'); } // 更新郵箱 $user = auth('api')->user(); $user->email = $request->input('email'); $user->save(); return $this->response->noContent(); } }
如果修改了隊(duì)列了,就要重啟隊(duì)列,命令sudo supervisorctl restart all
2.2 創(chuàng)建對(duì)應(yīng)路由
// 發(fā)送郵件驗(yàn)證碼 $api->post('email/code', [BindController::class, 'emailCode']); // 更新郵箱 $api->post('email/update', [BindController::class, 'updateEmail']);
2.3 創(chuàng)建發(fā)送郵件的類
運(yùn)行命令php artisan make:mail SendEmailCode
:
寫入:
<?php namespace AppMail; use IlluminateBusQueueable; use IlluminateMailMailable; use IlluminateQueueSerializesModels; use IlluminateSupportFacadesCache; class SendEmailCode extends Mailable { use Queueable, SerializesModels; protected $email; /** * Create a new message instance. * * @return void */ public function __construct($eamil) { $this->email = $eamil; } /** * Build the message. * * @return $this */ public function build() { // 生成code $code = rand(1000, 9999); // 獲取郵箱 // 使用緩存郵箱對(duì)應(yīng)的code Cache::put($this->email, $code, now()->addMinute(5)); // 5分鐘過期 return $this->view('emails.send-email-code', ['code' => $code]); } }
創(chuàng)建發(fā)送郵件的模版:
模版寫入:
郵箱驗(yàn)證碼是:{{$code}}
驗(yàn)證碼5分鐘內(nèi)有效,請(qǐng)及時(shí)使用!
2.4 測試效果
可以看到這邊收到郵箱驗(yàn)證碼。
測試更新的輸入郵箱不正確或者驗(yàn)證碼不正確:
輸入正確的郵箱和驗(yàn)證碼就會(huì)修改了。
到此這篇關(guān)于laravel的用戶修改密碼與綁定郵箱的文章就介紹到這了,更多相關(guān)laravel修改密碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
版權(quán)聲明:
本站所有文章和圖片均來自用戶分享和網(wǎng)絡(luò)收集,文章和圖片版權(quán)歸原作者及原出處所有,僅供學(xué)習(xí)與參考,請(qǐng)勿用于商業(yè)用途,如果損害了您的權(quán)利,請(qǐng)聯(lián)系網(wǎng)站客服處理。