Токен Laravel для напоминания пароля всегда не соответствует

#php #laravel #token #remember-me

#php #laravel #жетон #помни-я

Вопрос:

Привет, у меня какая-то странная проблема с системой напоминания пароля. Возвращаемым значением для этой функции всегда является несоответствие маркера пароля.

вот контроллер запоминания

   <?php

 class RemindersController extends Controller {

/**
 * Display the password reminder view.
 *
 * @return Response
 */
public function getRemind()
{
    return View::make('resetacc');
}

/**
 * Handle a POST request to remind a user of their password.
 *
 * @return Response
 */
public function postRemind()
{
    switch ($response = Password::remind(Input::only('email')))
    {
        case Password::INVALID_USER:
            return Redirect::back()->with('message', Lang::get($response));

        case Password::REMINDER_SENT:
            return Redirect::back()->with('message', Lang::get($response));
    }
}

/**
 * Display the password reset view for the given token.
 *
 * @param  string  $token
 * @return Response
 */
public function getReset($token = null)
{
    if (is_null($token)) App::abort(404);

    return View::make('resetpass')->with('token', $token);
}

/**
 * Handle a POST request to reset a user's password.
 *
 * @return Response
 */
public function postReset()
{
    $credentials = Input::only(
        'email', 'password', 'password_confirmation', 'token'
    );

    $response = Password::reset($credentials, function($user, $password)
    {
        $user->password = Hash::make($password);

        $user->save();
    });

    switch ($response)
    {
        case Password::INVALID_PASSWORD:
        case Password::INVALID_TOKEN:
            return Redirect::to('/reset')->with('message', Lang::get($response));
        case Password::INVALID_USER:
            return Redirect::back()->with('message', Lang::get($response));
        case Password::PASSWORD_RESET:
            return Redirect::to('/auth')->with('message', 'Password Reset anda berhasil, silahkan login.');
    }
}

}
 

и тот Routes.php

 Route::get('reset', function() {
    return View::make('resetacc');
});

Route::get('password/reset/{token}', array(
    'uses' => 'RemindersController@getReset',
    'as' => 'resetpass'
));
 

токен, хранящийся в базе данных, в равной степени совпадает с тем, который был предоставлен пользователю.

у меня есть laravel версии 4.1, затем обновлен до 4.2.5

это из-за процесса обновления?

Спасибо

Ответ №1:

Для полноты картины: эта ошибка также может означать, что токен просто истек.

Вы можете установить reminder.expire config/auth.php .

По умолчанию 60 минут.

https://laravel.com/docs/5.1/authentication#after-resetting-passwords

Комментарии:

1. Это был мой случай… Печально, что ошибка не является явной. Должен сказать «Срок действия токена истек» или что-то подобное…

Ответ №2:

Вам нужно добавить что-то подобное {{ Form::hidden('token', $token) }} в свою форму сброса.

Ответ №3:

Если у вас есть маршрутизация поддоменов в вашем приложении, вам нужно будет изменить свой метод getReset, чтобы включить параметр поддомена в список параметров функции.

     public function getReset($club="",$token = null)
    {
        if (is_null($token)) {
            throw new NotFoundHttpException;
        }

        return view('auth.reset')->with('token', $token);
    }