📅  最后修改于: 2023-12-03 15:17:15.369000             🧑  作者: Mango
当用户忘记他们的密码时,Laravel提供了一种重新发送密码重置链接的方式。然而,这需要用户进行身份验证才能访问该功能。在本文中,我们将介绍如何允许未经身份验证的用户重新发送密码重置链接。
创建一个能够访问“密码重置”页面的路由。您可以选择将其放在任何您想要的位置。
Route::get('forgot-password', 'Auth\ForgotPasswordController@showLinkRequestForm')->name('password.request');
打开 app/Http/Controllers/Auth/ForgotPasswordController.php
文件,找到以下代码:
public function __construct()
{
$this->middleware('guest');
}
将下面这行代码添加到 __construct
函数中,以允许未经身份验证的用户重新发送密码重置链接:
$this->middleware('guest')->except('logout');
现在,您需要创建一个允许未经身份验证的用户重新发送密码重置链接的视图。可以通过修改原来的 Auth 例子来创建视图。打开 resources/views/auth/forgot-password.blade.php
文件,复制并粘贴以下代码:
@extends('layouts.app')
@section('content')
<div class="container">
<div class="row justify-content-center">
<div class="col-md-8">
<div class="card">
<div class="card-header">{{ __('Reset Password') }}</div>
<div class="card-body">
@if (session('status'))
<div class="alert alert-success" role="alert">
{{ session('status') }}
</div>
@endif
<form method="POST" action="{{ route('password.email') }}">
@csrf
<div class="form-group row">
<label for="email" class="col-md-4 col-form-label text-md-right">{{ __('E-Mail Address') }}</label>
<div class="col-md-6">
<input id="email" type="email" class="form-control @error('email') is-invalid @enderror" name="email" value="{{ old('email') }}" required autocomplete="email" autofocus>
@error('email')
<span class="invalid-feedback" role="alert">
<strong>{{ $message }}</strong>
</span>
@enderror
</div>
</div>
<div class="form-group row mb-0">
<div class="col-md-6 offset-md-4">
<button type="submit" class="btn btn-primary">
{{ __('Send Password Reset Link') }}
</button>
</div>
</div>
</form>
</div>
</div>
</div>
</div>
</div>
@endsection
最后,您可以测试此功能。尝试在未经身份验证的情况下访问“忘记密码”页面,应该显示上面的表单。
现在,您已经知道如何允许未经身份验证的用户重新发送密码重置链接。为了使这个示例更加完整,您可以添加邮件发送逻辑,以向用户发送密码重置链接。