doucan4815 2018-02-02 15:49
浏览 918
已采纳

Laravel _如何将查询注入Auth :: user()

I'm making a blog with laravel. When I look into user authentication, I have a few issues here. I have 2 tables, one is users: id, name, ... the other is role: user_id, privilege .. I need to check whether a user is admin or not, I will need a function like isAdmin() or a $isAdmin attribute. This is my function placed in the app/providers/AuthServiceProvider.php:

private static $isAdmin;

public static function isAdmin() {
    if (isset(self::$isAdmin)) {
        return self::$isAdmin;
    }
    $user_privilege = DB::table('role')
        ->select('privilege')
        ->where([
            ['privilege', '=', 'admin'],
            ['user_id', '=', Auth::user()->id],
        ])
        ->get()
        ->first();
    self::$isAdmin = isset($user_privilege->privilege);
    return self::$isAdmin;
}

This code works fine, but this will require two queries to the database to check the user's admin rights. So I wanted to find a way to inject a query into Auth :: user () so that only one query would retrieve all the stuff I wanted. I'm a beginner with laravel. Can you help me?

  • 写回答

2条回答 默认 最新

  • doushi3803 2018-02-02 15:59
    关注

    I assume that user can have only one role. You can create isAdmin() method in the User model:

    public function isAdmin()
    {
        return auth()->user()->role->privilege === 'admin';
    }
    

    Define the relationship if you didn't do that yet:

    public function role()
    {
        return $this->hasOne(Role::class);
    }
    

    Then use it with auth()->user()->isAdmin().

    If a user can have many roles:

    public function isAdmin()
    {
        auth()->user()->loadMissing('roles');
        return auth()->user()->roles->contains('admin');
    }
    

    And the relationship:

    public function roles()
    {
        return $this->hasMany(Role::class);
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?