我正在开发一个电子商务应用程序,它正在使用laravel的身份验证。它为我提供了所有登录/注册/重置密码逻辑和视图。登录和注册工作正常,但重置视图给我一些错误。重置视图:
@extends('layouts.app')
@section('content')
<div class="container">
<div class="row">
<div class="col-md-8 col-md-offset-2">
<div class="panel panel-default">
<div class="panel-heading">Reset password</div>
<div class="panel-body">
@if (session('status'))
<div class="alert alert-success">
{{ session('status') }}
</div>
@endif
<form class="form-horizontal" role="form" method="POST" action="{{ route('password.request') }}">
{{ csrf_field() }}
<input type="hidden" name="token" value="{{ $token }}">
<div class="form-group{{ $errors->has('email') ? ' has-error' : '' }}">
<label for="email" class="col-md-4 control-label">E-mail</label>
<div class="col-md-6">
<input id="email" type="email" class="form-control" name="email" value="{{ $email or old('email') }}" required autofocus>
@if ($errors->has('email'))
<span class="help-block">
<strong>{{ $errors->first('email') }}</strong>
</span>
@endif
</div>
</div>
<div class="form-group{{ $errors->has('password') ? ' has-error' : '' }}">
<label for="password" class="col-md-4 control-label">Password</label>
<div class="col-md-6">
<input id="password" type="password" class="form-control" name="password" required>
@if ($errors->has('password'))
<span class="help-block">
<strong>{{ $errors->first('password') }}</strong>
</span>
@endif
</div>
</div>
<div class="form-group{{ $errors->has('password_confirmation') ? ' has-error' : '' }}">
<label for="password-confirm" class="col-md-4 control-label">Confirm password</label>
<div class="col-md-6">
<input id="password-confirm" type="password" class="form-control" name="password_confirmation" required>
@if ($errors->has('password_confirmation'))
<span class="help-block">
<strong>{{ $errors->first('password_confirmation') }}</strong>
</span>
@endif
</div>
</div>
<div class="form-group">
<div class="col-md-6 col-md-offset-4">
<button type="submit" class="btn btn-primary">
Reset password
</button>
</div>
</div>
</form>
</div>
</div>
</div>
</div>
</div>
@endsection
当我没有登录时,我会在以下代码中获得: 未定义的变量:token :
<input type="hidden" name="token" value="{{ $token }}">
但是当我登录时,我没有收到任何错误,但它只是将我重定向到主页。我知道它必须是因为中间件,但记录的用户无法访问“密码重置”视图是没有意义的。任何想法?
TL; DR
验证路由(密码重置):
Route::group(['namespace' => 'Auth'], function () {
Route::get('/reset', 'ResetPasswordController@getPasswordResetView');
});
密码重置控制器:
<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\ResetsPasswords;
class ResetPasswordController extends Controller
{
use ResetsPasswords;
protected $redirectTo = '/home';
public function __construct()
{
$this->middleware('guest');
}
public function getPasswordResetView()
{
return view("auth/passwords/reset");
}
}
答案 0 :(得分:3)
您使用了错误的观点。当用户单击电子邮件中的重置链接时,视图reset.blade.php
用于显示密码重置页面。您正在查找的是email.blade.php
视图,其中显示了密码重置表单,用户可以在其中输入其电子邮件以重置密码。
这些是内置的身份验证路线
$this->get('password/reset', 'Auth\ForgotPasswordController@showLinkRequestForm')->name('password.request');
$this->get('password/reset/{token}', 'Auth\ResetPasswordController@showResetForm')->name('password.reset');
密码重置请求路由使用showLinkRequestForm
上的ForgotPasswordController
方法。
public function showLinkRequestForm()
{
return view('auth.passwords.email');
}
电子邮件密码重置路由使用showResetForm
上的ResetPasswordController
方法。
public function showResetForm(Request $request, $token = null)
{
return view('auth.passwords.reset')->with(
['token' => $token, 'email' => $request->email]
);
}
如您所见,控制器根据从重置链接收到的值设置$token
。
这两条路线也使用guest
中间件。这意味着只有在您未登录时才能查看它们。当您已经登录时尝试访问它们会将您重定向到RedirectIfAuthenticated
中间件中的路由集guest
中间件。
答案 1 :(得分:0)
您正在考虑的密码重置视图是一个忘记密码重置,这就是为什么它在您已经登录时重定向到家。
您获得的令牌错误可能是因为您没有关注Laravel在密码重置电子邮件中生成的令牌链接。