In modernen Webanwendungen ist das Zurücksetzen des Benutzerpassworts eine wesentliche Funktion. Ein gut konzipierter Prozess zum Zurücksetzen des Passworts kann nicht nur die Sicherheit des Benutzerkontos gewährleisten, sondern auch das Benutzererlebnis verbessern. Laravel ist ein beliebtes PHP-Webentwicklungs-Framework, das auch ein praktisches System zum Zurücksetzen von Passwörtern integriert. In diesem Artikel wird erläutert, wie Sie mit Laravel die Funktion zum Zurücksetzen des Passworts implementieren.
Environment -Vorbereitung
Schitieren Sie, bevor Sie beginnen, dass Sie die folgenden Installationen abgeschlossen haben:
In
, wenn Sie es nicht installiert haben Dennoch kann Laravel über den folgenden Befehl im Terminal installiert werden:
composer create-project --prefer-dist laravel/laravel project-name
Prozess zum Zurücksetzen des Passworts
Mail-Konfiguration
Zuerst müssen wir E-Mails in Laravel konfigurieren. Öffnen Sie die Datei.env
und fügen Sie die folgende Konfiguration hinzu:
MAIL_DRIVER=smtp MAIL_HOST=smtp.mxhichina.com MAIL_PORT=25 MAIL_USERNAME=youremail@example.com MAIL_PASSWORD=yourpassword MAIL_FROM_ADDRESS=youremail@example.com MAIL_ENCRYPTION=
.env
文件,在其中添加如下配置:'from' => [ 'address' => env('MAIL_FROM_ADDRESS', 'youremail@example.com'), 'name' => env('MAIL_FROM_NAME', 'Your Name'), ],
这里的配置需要根据您的实际情况进行修改,MAIL_DRIVER
指定了使用的邮件服务提供商,例如 smtp
、mailgun
或 sendmail
等,这里我们使用了阿里云邮件服务提供商 smtp.mxhichina.com
,并且需要填写您的邮箱用户名和密码。MAIL_FROM_ADDRESS
用于指定发送邮件的发送地址。
接下来,我们需要在 config/mail.php
文件中配置邮件发送选项,例如设置发件人名称和地址:
// Password Reset Routes Route::get('password/reset', 'Auth\ForgotPasswordController@showLinkRequestForm')->name('password.request'); Route::post('password/email', 'Auth\ForgotPasswordController@sendResetLinkEmail')->name('password.email'); Route::get('password/reset/{token}', 'Auth\ResetPasswordController@showResetForm')->name('password.reset'); Route::post('password/reset', 'Auth\ResetPasswordController@reset');
路由配置
现在,我们需要配置路由来处理密码重置操作。在 Laravel 中,我们可以使用自带的 Password 控制器来处理重置密码的逻辑。打开 routes/web.php
文件,添加以下路由:
<form method="POST" action="{{ route('password.email') }}"> @csrf <div> <input type="email" name="email" value="{{ old('email') }}" required autofocus placeholder="请输入您的邮箱地址"> </div> <div> <button type="submit">发送重置密码链接</button> </div> </form>
这里我们在 Auth
中使用了两个控制器,分别是 ForgotPasswordController
和 ResetPasswordController
,分别处理重置密码邮件发送和密码重置操作。
视图配置
接下来,我们需要添加视图来展示用户填写邮箱和密码的表单。我们可以使用类似以下代码片段的 Blade 模板代码实现:
<form method="POST" action="{{ route('password.update') }}" > @csrf <input type="hidden" name="token" value="{{ $token }}"> <div> <label for="email-input">邮箱</label> <input type="email" name="email" value="{{ $email ?? old('email') }}" required autofocus> </div> <div> <label for="password-input">新密码</label> <input type="password" name="password" required> </div> <div> <label for="password-confirm-input">确认新密码</label> <input type="password" name="password_confirmation" required> </div> <div> <button type="submit">重置密码</button> </div> </form>
在这个页面中,我们使用了一个表单来接受用户填写的邮箱地址,并且添加了一个发送按钮,点击这个按钮将会向该邮箱发送密码重置链接。
我们还需要添加另一个视图来允许用户输入新密码。类似以下代码片段可以用于实现一个这样的表单:
use Illuminate\Support\Facades\Password; class ForgotPasswordController extends Controller { use SendsPasswordResetEmails; } class ResetPasswordController extends Controller { use ResetsPasswords; protected $redirectTo = '/home'; public function showResetForm(Request $request, $token = null) { return view('auth.passwords.reset')->with( ['token' => $token, 'email' => $request->email] ); } }
这个表单需要用户填写新密码和确认密码,并且需要通过 $token
和 $email
参数来验证重置链接是否合法。这些参数可以在 ResetPasswordController@showResetForm
中获取。
控制器逻辑
我们在路由中使用了两个控制器来处理密码重置操作,分别是 ForgotPasswordController
和 ResetPasswordController
。
ForgotPasswordController
提供了一个 showLinkRequestForm()
方法,用于展示用户填写邮箱地址的表单。另外一个方法 sendResetLinkEmail()
将会向用户提供的邮箱地址发送含有密码重置链接的邮件,其中使用了 Password::sendResetLink()
方法来处理重置链接的生成和发送。
ResetPasswordController
中的 showResetForm()
方法将会展示用户输入新密码的表单,如果重置链接不合法则会返回到邮件链接过期的提示页面。reset()
方法则处理了用户填写重置密码表单并提交的逻辑,其中使用了 Password::reset()
Die Konfiguration hier muss entsprechend Ihrer tatsächlichen Situation geändert werden. MAIL_DRIVER
gibt den verwendeten E-Mail-Dienstanbieter an . Zum Beispiel smtp
, mailgun
oder sendmail
usw. Hier verwenden wir den Alibaba Cloud-E-Mail-Dienstanbieter smtp.mxhichina.com, und Sie müssen Ihren E-Mail-Benutzernamen und Ihr Passwort eingeben. <code>MAIL_FROM_ADDRESS
wird verwendet, um die Absenderadresse für den E-Mail-Versand anzugeben.
Als nächstes müssen wir die E-Mail-Versandoptionen in der Datei config/mail.php
konfigurieren, wie zum Beispiel den Namen und die Adresse des Absenders festlegen: rrreee
routes/web.php
und fügen Sie die folgenden Routen hinzu: Auth
, nämlich ForgotPasswordController
und ResetPasswordController übernimmt den E-Mail-Versand zum Zurücksetzen des Passworts bzw. das Zurücksetzen des Passworts. Wir müssen außerdem eine weitere Ansicht hinzufügen, damit der Benutzer ein neues Passwort eingeben kann. Ein Codeausschnitt ähnlich dem folgenden kann verwendet werden, um ein solches Formular zu implementieren:
rrreeeDieses Formular erfordert, dass der Benutzer ein neues Passwort eingibt und das Passwort bestätigt, und erfordert den $token
und $email
-Parameter, um zu überprüfen, ob der Reset-Link legitim ist. Diese Parameter können in ResetPasswordController@showResetForm
abgerufen werden.
ForgotPasswordController
und ResetPasswordController
. 🎜🎜ForgotPasswordController
stellt eine showLinkRequestForm()
-Methode bereit, um ein Formular anzuzeigen, in das Benutzer ihre E-Mail-Adressen eingeben können. Eine andere Methode sendResetLinkEmail()
sendet eine E-Mail mit einem Link zum Zurücksetzen des Passworts an die vom Benutzer angegebene E-Mail-Adresse. Die Methode Password::sendResetLink()
wird zur Verarbeitung verwendet Link zurücksetzen. Konfigurieren Sie die Generierung und den Versand von Links. 🎜🎜Die Methode showResetForm()
in ResetPasswordController
zeigt dem Benutzer das Formular zur Eingabe eines neuen Passworts an. Wenn der Link zum Zurücksetzen ungültig ist, wird zum E-Mail-Link zurückgekehrt Ablaufaufforderungsseite. Die Methode reset()
verwaltet die Logik, mit der der Benutzer das Formular zum Zurücksetzen des Passworts ausfüllt und absendet. Die Methode Password::reset()
wird verwendet, um das Passwort des Benutzers zu aktualisieren zur Datenbank. 🎜rrreee🎜🎜Verwenden der Passwort-Reset-Funktion🎜🎜🎜Da wir nun die Implementierung der Passwort-Reset-Funktion in Laravel abgeschlossen haben, versuchen wir, die implementierte Funktion zum Zurücksetzen des Passworts zu verwenden: 🎜🎜🎜Öffnen Sie die Anmeldeseite der Anwendung. Klicken Sie auf „Passwort vergessen“; 🎜🎜 Geben Sie Ihre registrierte E-Mail-Adresse ein und klicken Sie auf die Schaltfläche „Passwort zurücksetzen senden“. 🎜🎜 Öffnen Sie Ihre E-Mail, suchen Sie den Link zum Zurücksetzen des Passworts und klicken Sie darauf die Schaltfläche „Senden“. 🎜🎜🎜Wenn alles gut geht, wurde Ihr Passwort erfolgreich zurückgesetzt! 🎜🎜🎜Zusammenfassung🎜🎜In diesem Artikel stellen wir vor, wie man mit Laravel eine grundlegende Funktion zum Zurücksetzen des Passworts implementiert. In modernen Webanwendungen ist das Zurücksetzen von Passwörtern eine notwendige Funktion. Nur ein gut konzipierter und implementierter Prozess zum Zurücksetzen von Passwörtern kann die Sicherheit von Benutzerkonten und das Benutzererlebnis gewährleisten. Ich glaube, dass die Passwortsicherheit und das Benutzererlebnis des Benutzers verbessert werden, nachdem Sie die in diesem Artikel beschriebenen Techniken erlernt und die Funktion zum vollständigen Zurücksetzen des Passworts implementiert haben.
Das obige ist der detaillierte Inhalt vonSo implementieren Sie die Funktion zum Zurücksetzen des Passworts in Laravel. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!