#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);
}