Heim  >  Artikel  >  PHP-Framework  >  So implementieren Sie die Funktion zum Zurücksetzen des Passworts in Laravel

So implementieren Sie die Funktion zum Zurücksetzen des Passworts in Laravel

PHPz
PHPzOriginal
2023-04-21 10:05:491107Durchsuche

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:

  • Php 7.2 und höher
  • Composer 2 und über
  • Laravel 5.5 und höher

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

  1. Der Prozess zum Zurücksetzen des Passworts von Laravel basiert auf einer E-Mail-Benachrichtigung. Die Schritte sind wie folgt:
  2. Der Benutzer übermittelt die E-Mail-Adresse und die Link zur Anwendung, die das Passwort zurücksetzen muss.
  3. Die Anwendung sendet eine E-Mail mit einem Link zum Zurücksetzen an die Mailbox des Benutzers.
  4. Die Anwendung ermittelt, ob der Link abgelaufen und legal ist.
  5. Wenn der Link legal ist, wird auf der Seite ein Formular zur Eingabe eines Passworts angezeigt.
  6. Der Benutzer gibt ein neues Passwort ein.
  7. Die App setzt das Benutzerpasswort zurück.
Deshalb müssen wir jeden Schritt dieses Prozesses umsetzen.

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 指定了使用的邮件服务提供商,例如 smtpmailgunsendmail 等,这里我们使用了阿里云邮件服务提供商 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(&#39;password.email&#39;) }}">
    @csrf
    <div>
        <input type="email" name="email" value="{{ old(&#39;email&#39;) }}" required autofocus placeholder="请输入您的邮箱地址">
    </div>
    <div>
        <button type="submit">发送重置密码链接</button>
    </div>
</form>

这里我们在 Auth 中使用了两个控制器,分别是 ForgotPasswordControllerResetPasswordController,分别处理重置密码邮件发送和密码重置操作。

视图配置

接下来,我们需要添加视图来展示用户填写邮箱和密码的表单。我们可以使用类似以下代码片段的 Blade 模板代码实现:

<form method="POST" action="{{ route(&#39;password.update&#39;) }}" >
    @csrf
    <input type="hidden" name="token" value="{{ $token }}">
    <div>
        <label for="email-input">邮箱</label>
        <input type="email" name="email" value="{{ $email ?? old(&#39;email&#39;) }}" 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 中获取。

控制器逻辑

我们在路由中使用了两个控制器来处理密码重置操作,分别是 ForgotPasswordControllerResetPasswordController

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

Routing-Konfiguration

    Jetzt brauchen wir um Route so zu konfigurieren, dass Vorgänge zum Zurücksetzen von Passwörtern verarbeitet werden. In Laravel können wir den integrierten Passwort-Controller verwenden, um die Logik zum Zurücksetzen von Passwörtern zu verwalten. Öffnen Sie die Datei routes/web.php und fügen Sie die folgenden Routen hinzu:
  1. rrreee
  2. Hier verwenden wir zwei Controller in Auth, nämlich ForgotPasswordController und ResetPasswordController übernimmt den E-Mail-Versand zum Zurücksetzen des Passworts bzw. das Zurücksetzen des Passworts.
  3. Ansichtskonfiguration
  4. Als nächstes müssen wir eine Ansicht hinzufügen, um das Formular anzuzeigen, in dem Benutzer ihre E-Mail-Adresse und ihr Passwort eingeben können. Um dies zu erreichen, können wir einen Blade-Vorlagencode verwenden, der dem folgenden Codeausschnitt ähnelt:
  5. rrreee
  6. Auf dieser Seite verwenden wir ein Formular, um die vom Benutzer eingegebene E-Mail-Adresse zu akzeptieren, und fügen eine Schaltfläche zum Senden hinzu Nachricht an die E-Mail-Adresse.

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:

rrreee

Dieses 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.

Controller-Logik🎜🎜🎜Wir verwenden beim Routing zwei Controller, um Vorgänge zum Zurücksetzen von Passwörtern abzuwickeln, nämlich 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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn