我在admin用户,它拥有管理员角色,但是当我添加一个条件来检查用户是否是admin时,它总是返回false。我找不到问题所在。这是我的代码:
这是我的角色表:
这是我的用户表:
我在我的用户模型中设置了关系,并在END OF THE CODE中设置了一个条件,它将检查用户是否为管理员:
/**
* The attributes that are mass assignable.
*
* @var array<int, string>
*/
protected $fillable = [
'name',
'email',
'password',
];
/**
* The attributes that should be hidden for serialization.
*
* @var array<int, string>
*/
protected $hidden = [
'password',
'remember_token',
];
/**
* The attributes that should be cast.
*
* @var array<string, string>
*/
protected $casts = [
'email_verified_at' => 'datetime',
];
public function role() {
return $this->belongsTo('App\Models\Role');
}
public function isAdmin() {
if($this->role->name == 'administrator')
return true;
else
return false;
}
}
然后,我创建了一个中间件,如果用户是管理员,它将允许我进入管理员页面,否则它将重定向到根:
然后在最后我添加了路线与控制器:
这里是控制器,如果你需要它:
指令集
2条答案
按热度按时间kq4fsx7k1#
首先,路由操作应该是:
而不是检查用户是否是admin,您可以在中间件中这样做:
svmlkihl2#
我发现我的错误,所以我跑:
它在页面上呈现了这样的内容:
我有他们:
但这意味着:
问题是,我把一个额外的空间时,我添加到我的数据库的角色名称,要知道,因为这是一个很难看到的错误。
注意间距!
现在起作用了!!