我有一个登录用户,这里的代码有效:
@if( Auth::check() )
Logged in as: {{ Auth::user()->firstname }} {{ Auth::user()->lastname }}
@endif
我正在使用 zizaco/entrust,一切正常。我已经创建了角色和权限,并为我的用户授予了具有管理权限的管理员角色。
那么为什么这不起作用:
$user = Auth::user();
print_r($user->hasRole('admin'));
如果我 print_r $user 我可以看到 Auth 用户已加载,但 hasRole 不起作用。我当时只是在刀片模板中测试这一点,但在控制器中尝试了它,得到了相同的结果。我的错误是:
BadMethodCallException in Builder.php line 1992:
Call to undefined method Illuminate\Database\Query\Builder::hasRole()
我的用户模型:
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
use Zizaco\Entrust\Traits\EntrustUserTrait;
class User extends Model {
use EntrustUserTrait;
protected $table = 'users';
public $timestamps = true;
use SoftDeletes;
protected $dates = ['deleted_at'];
}
UPDATE
当我以这种方式查找用户时,我意识到 hasRole 对我有用(返回 App\Models\User 对象):
$user = \App\Models\User::find( \Auth::user()->id );
但当我以这种方式找到用户时则不然(返回 App\User Object ):
$user = \Auth::user();
我宁愿认为它会以另一种方式工作,当我拉出 App\User 时,我可以访问 hasRole,但不一定在我搜索用户时访问。我认为 hasRole 可以直接从 Auth::user() 工作,而不必使用用户模型查找用户......???