Laravel 8 + Jetsream: как перенаправить на предыдущую страницу после входа в систему?

У меня есть базовая веб-страница, на которой я хочу, чтобы пользователь мог щелкнуть ссылку для входа, пройти через логин, а затем вернуться на эту страницу (а не на домашнюю страницу). На странице есть некоторые функции, которые можно увидеть, только когда пользователь вошел в систему.

У меня проблемы с этим, независимо от того, что когда я захожу в систему, он возвращается на домашнюю страницу после аутентификации или того, что я установил как константу, а не на предыдущую страницу.

Fortify.php имеет домашний путь, который является константой, поэтому я также не могу обновить его с помощью выражения ...

  'home' => RouteServiceProvider::HOME,

Вот промежуточное ПО RedirectIfAuthenticated.php, это стандартный Laravel, и мне интересно, что нужно обновить.

    <?php

namespace App\Http\Middleware;

use App\Providers\RouteServiceProvider;
use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;

class RedirectIfAuthenticated
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @param  string|null  ...$guards
     * @return mixed
     */
    public function handle(Request $request, Closure $next, ...$guards)
    {
        $guards = empty($guards) ? [null] : $guards;

        foreach ($guards as $guard) {
            if (Auth::guard($guard)->check()) {
                return redirect(RouteServiceProvider::HOME);
            }
        }

        return $next($request);
    }
}

Я также должен отметить, что если я добавлю на страницу маршрут промежуточного программного обеспечения, как в приведенном ниже примере, то процесс будет работать правильно, поскольку вернет пользователя обратно на предыдущую страницу.

Route::middleware(['auth:sanctum', 'verified'])->get('/agenda', function () {
    return view('agenda');
})->name('agenda');

Однако мне нужно, чтобы пользователь мог просматривать страницу agenda, даже если он гость ... но после входа в систему он будет возвращен на страницу повестки дня, которая будет иметь некоторые дополнительные функции. К сожалению, я ничего не могу найти в документации по этому поводу.


person Daniel C    schedule 12.02.2021    source источник
comment
update, похоже, что этот рабочий процесс не встроен в jetstream. я внес изменения на основе следующей ветки комментариев, которая оказалась полезной, хотя проверка электронной почты не совсем работает, как планировалось после этого изменения ... см .: laracasts.com/discuss/channels/laravel/   -  person Daniel C    schedule 14.02.2021


Ответы (2)


В AuthenticatesUsers.php

protected function sendLoginResponse(Request $request)
{
    $request->session()->regenerate();

    $this->clearLoginAttempts($request);

    if ($response = $this->authenticated($request, $this->guard()->user())) {
        return $response;
    }

    return $request->wantsJson()
                ? new JsonResponse([], 204)
                : redirect()->back();
}

Или вы можете сделать это в своем контроллере входа по умолчанию в строке 31

protected $redirectTo = "/your-path";
person Naeem Ijaz    schedule 12.02.2021
comment
Спасибо за ваше предложение. У меня нет этого файла AuthenticatesUsers.php. Я на Laravel 8. - person Daniel C; 12.02.2021
comment
вы следуете второй остановке? - person Naeem Ijaz; 12.02.2021
comment
можешь показать свой код входа - person Naeem Ijaz; 12.02.2021

Когда промежуточное программное обеспечение аутентификации обнаруживает неаутентифицированного пользователя, оно перенаправляет пользователя на имя входа в систему с именем route. Вы можете изменить это поведение, обновив функцию redirectTo в app/Http/Middleware/Authenticate.php файле вашего приложения.

https://laravel.com/docs/8.x/authentication#redirecting-unauthenticated-users

person shalini    schedule 12.02.2021
comment
Спасибо за ваш ответ. У меня есть эта функция, как ее изменить, чтобы она переходила на предыдущую страницу? защищенная функция redirectTo ($ request) {if (! $ request- ›extendsJson ()) {return route ('login'); - person Daniel C; 12.02.2021
comment
if(!session()->has('url.intended')) { session(['url.intended' => url()->previous()]); } используйте переменную сеанса, она внутренне перенаправляет на этот URL-адрес сеанса, если установлено, ИЛИ добавьте свойство redirectTo как url ​​() - ›previous (); - person shalini; 12.02.2021
comment
спасибо, к сожалению, это тоже не работает. Думаю, у меня проблема с Laravel 8 и Jetstream ... буду продолжать попытки. - person Daniel C; 13.02.2021
comment
@DanielC Привет, я реализовал собственную логику сразу после входа в laravel fortify. Проверьте мое предложение. - person Akhzar Javed; 13.02.2021