今回は、Laravelでパスワードリセットを実装する手順について詳しく説明します。Laravelでパスワードリセットを実装するための注意事項は何ですか?実際のケースを見てみましょう。
はじめに
この機能をすぐに実装したいですか?新しくインストールした Laravel アプリケーションで php army make:auth
を実行し (このコマンドを既に実行している場合は無視して構いません)、ブラウザで http://your-app.dev にアクセスします。 /register またはアプリケーションに割り当てられたその他の URL を使用すると、このコマンドにより、ユーザーのログインphp artisan make:auth
(如果你已经执行过此命令,可忽略),然后在浏览器中访问 http://your-app.dev/register 或者其他分配给应用的 URL,该命令会生成用户登录注册所需要的所有东西,包括密码重置!
大多数 Web 应用都提供了为用户重置密码的功能,Laravel 也不例外,Laravel 提供了用于发送密码重置链接及实现密码重置逻辑的便捷方法,而不需要你在每个应用中自己重复实现。
注:在使用 Laravel 提供的密码重置功能之前, User 模型必须使用了 IlluminateNotificationsNotifiable trait。
数据库相关
开始之前,先验证 AppUser 模型实现了 IlluminateContractsAuthCanResetPassword
契约。当然,Laravel 自带的 AppUser 模型已经实现了该接口,并使用 IlluminateAuthPasswordsCanResetPassword trait 来包含实现该接口需要的方法。
生成重置令牌表迁移
接下来,用来存储密码重置令牌的表必须被创建,Laravel 已经自带了这张表的迁移,就存放在 database/migrations 目录。所以,你所要做的仅仅是运行迁移:
php artisan migrate
这张表就是 password_resets :
路由
Laravel 自带了 AuthForgotPasswordController
和 AuthResetPasswordController
控制器(这两个控制器类会通过 php artisan make:auth 命令自动生成),分别用于发送密码重置链接邮件和重置用户密码功能。重置密码所需的路由都已经通过 make:auth 命令自动生成了:
php artisan make:auth
对应路由定义在 IlluminateRoutingRouter 的 auth 方法中:
视图
和路由一样,重置密码所需的视图文件也通过 make:auth 命令一并生成了,这些视图文件位于
<a href="//m.sbmmt.com/wiki/61.html" target="_blank">resource</a>s/views/auth/passwords
目录下,你可以按照所需对生成的文件进行相应修改。
重置密码
定义好重置用户密码路由和视图后,只需要在浏览器中通过 /password/reset 访问这个入口路由。框架自带的 ForgotPasswordController
已经包含了发送密码重置链接邮件的逻辑, ResetPasswordController
登録に必要なものがすべて生成されます。パスワードのリセット!
ほとんどの Web アプリケーションはユーザーにパスワードをリセットする機能を提供しており、Laravel も例外ではなく、各アプリケーションでパスワードを再設定する必要なく、パスワード リセット リンクを送信し、パスワード リセット ロジックを実装するための便利な方法を提供します。
注: Laravel が提供するパスワード リセット関数を使用する前に、User モデルは IlluminateNotificationsNotifiable トレイトを使用する必要があります。
データベース関連
開始する前に、AppUser モデルがIlluminateContractsAuthCanResetPassword
コントラクトを実装していることを確認してください。もちろん、Laravel 独自の AppUser モデルはすでにこのインターフェイスを実装しており、IlluminateAuthPasswordsCanResetPassword トレイトを使用して、このインターフェイスの実装に必要なメソッドを含めています。
リセットトークンテーブルの移行を生成する
🎜 次に、パスワードリセットトークンを保存するために使用されるテーブルを作成する必要があります。Laravel には、このテーブルの移行がすでに組み込まれており、database/migrations ディレクトリに保存されます。したがって、あなたがしなければならないのは、移行を実行することだけです: 🎜🎜phpあーちっく移行
🎜🎜このテーブルはpassword_resetsです: 🎜🎜 🎜🎜🎜ルーティング🎜🎜🎜🎜Laravel には AuthForgotPasswordController
と A が付属していますuthResetPasswordController
コントローラー 🎜 (これら 2 つのコントローラー クラスは、phpArtisan make:auth コマンドによって自動的に生成されます)パスワード リセット リンクの電子メールを送信し、ユーザー パスワードをリセットするために使用されます。パスワードのリセットに必要なルートは、make:auth コマンドによって自動的に生成されています: 🎜🎜phpArtisan make:auth
🎜🎜は ルート定義🎜IlluminateRoutingRouterのauthメソッド内: 🎜🎜 🎜🎜🎜🎜Views🎜🎜🎜🎜 ルーティングと同様に、パスワードのリセットに必要なビュー ファイルも make:auth コマンドによって生成されます。これらのビュー ファイルは次の場所にあります。 🎜🎜<a href="//m.sbmmt.com/wiki/61.html" target="_blank">resource🎜s/views/auth/passwords </a>
ディレクトリ内で、生成されたファイルは、必要に応じて変更できます。 🎜🎜🎜🎜パスワードのリセット🎜🎜🎜🎜ユーザー パスワードのリセット ルートとビューを定義した後は、ブラウザーの /password/reset を介してこのエントリ ルートにアクセスするだけで済みます。フレームワークに付属する ForgotPasswordController
には、パスワード リセット リンクの電子メールを送信するロジックがすでに含まれており、ResetPasswordController
には、ユーザー パスワードをリセットするロジックが含まれています: 🎜🎜🎜 🎜🎜登録メールを入力し、「パスワード リセット リンクを送信」をクリックすると、パスワード リセット リンクがメール アドレスに送信されます: 🎜🎜🎜 🎜🎜メールを開くと、次のようなパスワード リセット メールが届きます: 🎜🎜🎜 🎜🎜パスワードのリセットボタンをクリックしてパスワードのリセットページに入ります: 🎜🎜🎜🎜フォームに記入して送信した後、パスワードをリセットできます。
パスワードがリセットされると、ユーザーは自動的にアプリケーションにログインし、/home にリダイレクトされます。 ResetPasswordController の redirectTo 属性を定義することで、パスワードのリセットが成功した後のリダイレクト リンクをカスタマイズできます:
protected $redirectTo = '/dashboard';
protected $redirectTo = '/dashboard';
注:默认情况下,密码重置令牌一小时内有效,你可以通过修改 config/auth.php 文件中的选项 expire 来改变有效时间。
自定义
自定义认证 Guard
在配置文件 auth.php 中,可以配置多个“guards”,以便用于实现基于多用户表的独立认证,你可以通过重写内置的 ResetPasswordController 控制器上的 guard 方法来使用你所选择的 guard,该方法将会返回一个 guard 实例:
use Illuminate\Support\Facades\Auth; protected function guard() { return Auth::guard('guard-name'); }
自定义密码 broker
在配置文件 auth.php 中,可以配置多个密码,以便用于重置多个用户表的密码 broker,同样,可以通过重写自带的 ForgotPasswordController 和 ResetPasswordController 控制器中的 broker 方法来使用你所选择的 broker:
use IlluminateSupportFacadesPassword;
/** * 获取密码重置期间所使用的broker. * * @return PasswordBroker * @translator laravelacademy.org */ protected function broker() { return Password::broker('name'); }
自定义密码重置邮件
你可以很方便地编辑发送密码重置链接给用户的通知类实现自定义密码重置邮件,要实现这一功能,需要重写 User 模型上的 sendPasswordResetNotification
設定ファイル auth.php では、複数の「ガード」を設定できます。複数のユーザー テーブルに基づく認証では、組み込みの ResetPasswordController コントローラーのガード メソッドをオーバーライドすることで、選択したガードを使用できます。これにより、ガード インスタンスが返されます:
/** * 发送密码重置通知. * * @param string $token * @return void */ public function sendPasswordResetNotification($token) { $this->notify(new ResetPasswordNotification($token)); }
設定ファイル auth.php では、複数のパスワードを設定して複数のユーザー テーブルのパスワード ブローカーをリセットできます。同様に、オーバーライドすることで選択したブローカーを使用できます。組み込みの ForgotPasswordController および ResetPasswordController コントローラーのブローカー メソッド:
use IlluminateSupportFacadesPassword;
sendPasswordResetNotification
メソッドを書き直す必要があります。通知を送信するには、任意の通知クラスを使用できます。このメソッドで受信する最初のパラメーターは、パスワードのリセット $token: 🎜rrreee🎜 この記事の場合のメソッドをマスターしたと思います。 、PHP 中国語 Web サイトの他の関連記事にも注目してください。 🎜🎜推奨読書: 🎜🎜🎜Laravel は Redis を使用してセッションステップを詳細に共有します🎜🎜🎜🎜🎜php 再帰関数ケースの使用法の詳細🎜🎜🎜以上がLaravelでパスワードリセットを実装する手順の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。