首页 文章

Laravel密码重置错误

提问于
浏览
1

我正在开发一个电子商务应用程序,它正在使用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

当我没有登录时,我得到: Undefined variable: 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");
    }
}

2 回答

  • 0

    你使用的是错误的观点 . 当用户单击电子邮件中的重置链接时,视图 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');
    

    密码重置请求路由在 ForgotPasswordController 上使用 showLinkRequestForm 方法 .

    public function showLinkRequestForm()
    {
        return view('auth.passwords.email');
    }
    

    电子邮件密码重置路由在 ResetPasswordController 上使用 showResetForm 方法 .

    public function showResetForm(Request $request, $token = null)
    {
        return view('auth.passwords.reset')->with(
            ['token' => $token, 'email' => $request->email]
        );
    }
    

    如您所见,控制器根据从重置链接接收的值设置 $token .

    这两条路线也使用 guest 中间件 . 这意味着只有当您已经登录时才能查看它们会将您重定向到 RedirectIfAuthenticated 中间件中的路由集,这只是 guest 中间件 .

  • 3

    您正在考虑的密码重置视图是一个忘记密码重置,这就是为什么它在您已经登录时重定向到家 .

    您获得的令牌错误可能是因为您没有关注Laravel在密码重置电子邮件中生成的令牌链接 .

相关问题