4 回答

TA貢獻1856條經驗 獲得超5個贊
我一直在尋找基于守衛的答案,我希望檢查守衛而不是基于守衛類型的重定向。但是我找不到解決方案。
然而,我找到了另一個可以完成工作的解決方案,但它并不像我正在尋找的答案那么動態。然而,它對我來說工作得很好
在
應用\Http\Middleware\Authinticate.php
類中,添加以下代碼:
protected function redirectTo($request)
{
if (! $request->expectsJson()) {
if($request->is('admin') || $request->is('admin/*'))
return route('admin.login');
return route('login');
}
}
另外,不要忘記為所有管理路由添加前綴 admin/ 。希望這個答案對您有幫助。

TA貢獻1946條經驗 獲得超4個贊
轉到應用程序/Exception/Handler.php
使用這個類
use Illuminate\Auth\AuthenticationException;
并在類中添加這個函數
protected function unauthenticated($request, AuthenticationException $exception)
{
if (request()->expectsJson()) {
return Response()->json(['error' => 'UnAuthorized'], 401); //exeption for api
}
$guard = data_get($exception->guards(), 0);
switch ($guard) {
case 'admin':
$login = 'admin.login';
break;
default:
$login = 'login';
break;
}
return redirect()->guest(route($login));
}

TA貢獻1828條經驗 獲得超3個贊
我不確定這是否是正確的方法,我重寫了handle方法,這樣我就可以從中獲取守衛,如下所示:
protected $guards = [];
public function handle($request, Closure $next, ...$guards)
{
$this->guards = $guards;
return parent::handle($request, $next, ...$guards);
}
protected function redirectTo($request)
{
if (in_array("admin", $this->guards)) {
return "admin/login";
}
}

TA貢獻1775條經驗 獲得超8個贊
好的,我已經解決了,我想這是一個很好的方法。我創建了一個中間件,并要求中間件上的身份驗證防護。
首先我創建中間件
class IsAdmin
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
if (Auth::guard('admin')->check())
return $next($request);
else
return redirect('/admin/login');
}
}
然后我將中間件放入內核文件中
protected $routeMiddleware = [
'auth' => \App\Http\Middleware\Authenticate::class,
'isAdmin' => \App\Http\Middleware\IsAdmin::class,
最后,我更改了路由的中間件
Route::get('/admin', 'AdminController@index')->name('admin');
現在它工作正常,但如果你有更好的解決方案,我真的很想知道。
- 4 回答
- 0 關注
- 250 瀏覽
添加回答
舉報