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
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";
Когда промежуточное программное обеспечение auth обнаруживает неаутентифицированного пользователя, оно перенаправляет пользователя на имя входа в систему с именем route. Вы можете изменить это поведение, обновив функцию redirectTo в своем приложении
app/Http/Middleware/Authenticate.php
файл
https://laravel.com/docs/8.x/authentication#redirecting-unauthenticated-users