中间件没有按预期工作 - Laravel

时间:2017-04-02 02:51:55

标签: php laravel laravel-middleware

我想制作一个中间件来保护laravel 5.2 app中的管理路由。 user_type不是我的数据库中的users表中的字段,但是在一个单独的表中:  enter image description here

管理员的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 !!

为什么会发生这种情况,我该如何解决?

2 个答案:

答案 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' => []]);

}