laravel的用戶修改密碼與綁定郵箱的詳細操作

一、修改密碼

1.1 創建修改密碼控制器

運行命令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個字符',
            'old_password.max' => '舊密碼最多16個字符',
        ]);

        // 舊密碼
        $old_password = $request->input('old_password');
        // 用戶實例
        $user = auth('api')->user();
        // 驗證舊密碼是否正確
        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 創建修改密碼路由

 // 修改密碼
            $api->post('password/update', [PasswordController::class, 'updatePassword']);

在這裡插入圖片描述

1.3 測試效果

在這裡插入圖片描述

二、綁定郵箱

 2.1 綁定郵箱控制器

運行命令php artisan make:controller Auth/BindController創建綁定郵箱的控制器:

在這裡插入圖片描述

寫入發送郵箱驗證碼和更新郵箱的處理函數:

<?php

namespace App\Http\Controllers\Auth;

use App\Http\Controllers\BaseController;
use App\Mail\SendEmailCode;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Mail;

class BindController extends BaseController
{
    /**
     * 獲取郵件的驗證碼
     */
    public function emailCode(Request $request) {
        $request->validate([
            'email' => 'required|email'
        ]);

        // 發送驗證碼到郵件
        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' => "驗證碼不能為空",
        ]);

        // 驗證code是否正確
        if (cache($request->input('email')) != $request->input('code')) {
            return $this->response->errorBadRequest('驗證碼或郵箱錯誤!');
        }

        // 更新郵箱
        $user = auth('api')->user(); 
        $user->email = $request->input('email');
        $user->save();
        return $this->response->noContent();
    } 
}

如果修改瞭隊列瞭,就要重啟隊列,命令sudo supervisorctl restart all

2.2 創建對應路由

  // 發送郵件驗證碼
            $api->post('email/code', [BindController::class, 'emailCode']);

            // 更新郵箱
            $api->post('email/update', [BindController::class, 'updateEmail']);

在這裡插入圖片描述

2.3 創建發送郵件的類

運行命令php artisan make:mail SendEmailCode:

在這裡插入圖片描述

寫入:

<?php

namespace App\Mail;

use Illuminate\Bus\Queueable;
use Illuminate\Mail\Mailable;
use Illuminate\Queue\SerializesModels;
use Illuminate\Support\Facades\Cache;

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);

        // 獲取郵箱

        // 使用緩存郵箱對應的code
        Cache::put($this->email, $code, now()->addMinute(5)); // 5分鐘過期

        return $this->view('emails.send-email-code', ['code' => $code]);
    }
}

在這裡插入圖片描述

創建發送郵件的模版:

在這裡插入圖片描述

模版寫入:

<h3>郵箱驗證碼是:{{$code}}</h3>
<h3>驗證碼5分鐘內有效,請及時使用!</h3>

2.4 測試效果

在這裡插入圖片描述

可以看到這邊收到郵箱驗證碼。
測試更新的輸入郵箱不正確或者驗證碼不正確:

在這裡插入圖片描述

輸入正確的郵箱和驗證碼就會修改瞭。

到此這篇關於laravel的用戶修改密碼與綁定郵箱的文章就介紹到這瞭,更多相關laravel修改密碼內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: