Laravel Redirect на страницу входа после сброса пароля - PullRequest
0 голосов
/ 04 мая 2019

Мне нужно перенаправить на страницу входа после сброса пароля.Можете ли вы, ребята, помочь мне ... Он автоматически перенаправляет на '/' URL.

Ответы [ 3 ]

0 голосов
/ 04 мая 2019

В Laravel 5.8 вы можете сделать это - в вашем ResetPasswordController должно быть как ниже, оно будет работать

<?php

namespace App\Http\Controllers\Auth;

use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\ResetsPasswords;

use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Str;
use Illuminate\Auth\Events\PasswordReset;

class ResetPasswordController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Password Reset Controller
    |--------------------------------------------------------------------------
    |
    | This controller is responsible for handling password reset requests
    | and uses a simple trait to include this behavior. You're free to
    | explore this trait and override any methods you wish to tweak.
    |
    */

    use ResetsPasswords;

    /**
     * Where to redirect users after resetting their password.
     *
     * @var string
     */
    protected $redirectTo = '/home';

    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('guest');
    }


    protected function resetPassword($user, $password)
    {
        $user->password = Hash::make($password);

        $user->setRememberToken(Str::random(60));

        $user->save();

        event(new PasswordReset($user));

        return redirect('login');
    }
}
0 голосов
/ 06 мая 2019

Единственное решение, которое я получил, - это изменение функции в файле ResetPasswords.php, расположенном в папке vendor / laravel / framework / src / lightingate / Foundation / Auth.

 protected function resetPassword($user, $password)
{
    $user->password = Hash::make($password);

    $user->setRememberToken(Str::random(60));

    $user->save();

    event(new PasswordReset($user));

    return redirect()->route('login');
}
0 голосов
/ 04 мая 2019

если вы используете авторизацию laravel, вы можете найти ResetPasswordController здесь:

 App\Http\Controllers\Auth\ResetPasswordController

и просто измените:

protected $redirectTo

на нужный маршрут.

если вы хотите игнорировать логин после сброса пароля, вам следует отредактировать функцию resetPassword в признаке ResetPasswords, который используется в ResetPasswordController, как показано ниже:

    protected function resetPassword($user, $password)
{
    $user->password = Hash::make($password);

    $user->setRememberToken(Str::random(60));

    $user->save();

    event(new PasswordReset($user));

    //you should comment below and redirect any route you want like:
    //   return redirect('http://example.com');
    $this->guard()->login($user);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...