我想制作一个中间件来保护laravel 5.2 app中的管理路由。 user_type不是我的数据库中的users表中的字段,但是在一个单独的表中:
管理员的user_type_id为4 我制作了这个中间件:
class AdminMiddleware
{
public function handle($request, Closure $next)
{
$authedUserID = Auth::id();
$user = User::query()
->leftjoin('users_user_types as uut', 'uut.user_id', '=', 'users.id')
->where('uut.user_id',"=","$authedUserID")
->get(['users.*',
'uut.user_type_id as userType'])->first();
if ($user['userType'] !=4)
{
return redirect('/home');
}
return $next($request);
}
}
并将其放在kernel.php中的$ routeMiddleware数组中:
'admin' => \App\Http\Middleware\AdminMiddleware::class
这是我想要应用我的中间件的管理员路线之一:
Route::get('ptyadmin', 'AdminController@show')->middleware('admin');
问题是当我使用admin用户(user_type = 4)或普通用户(user_type = 1)进入此路由时,它会在两种情况下重定向到/ home !!
为什么会发生这种情况,我该如何解决?
答案 0 :(得分:1)
first
方法返回对象
if ($user->userType !=4)
另请使用select
代替get
->select(['users.*','uut.user_type_id as userType'])->first();
答案 1 :(得分:0)
当我将jwt.auth中间件放在routes.php中时,它可以工作:
Route::get('ptyadmin', 'AdminController@show')
->middleware('jwt.auth')
->middleware('admin');
而不是把它放在AdminController中:
public function __construct(User $user, JWTAuth $jwtauth)
{
$this->middleware('jwt.auth', ['except' => []]);
}