laravel 无法比较数据库中的名称列

2cmtqfgy  于 2022-11-26  发布在  其他
关注(0)|答案(2)|浏览(87)

我在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;
}

}
然后,我创建了一个中间件,如果用户是管理员,它将允许我进入管理员页面,否则它将重定向到根:

然后在最后我添加了路线与控制器:

这里是控制器,如果你需要它:

指令集

kq4fsx7k

kq4fsx7k1#

首先,路由操作应该是:

Route::get('/admin', [AdminController::class, 'index'];

而不是检查用户是否是admin,您可以在中间件中这样做:

if (auth()->user()->role->name == 'administrator') {
    return $next($request);
} else {
    return redirect('/');
}
svmlkihl

svmlkihl2#

我发现我的错误,所以我跑:

return dd(Auth::user()->role->name)

它在页面上呈现了这样的内容:

"administrator  "

我有他们:

Auth::user()->role->name == "administrator"

但这意味着:

"administrator  " == "administrator"

问题是,我把一个额外的空间时,我添加到我的数据库的角色名称,要知道,因为这是一个很难看到的错误。
注意间距!
现在起作用了!!

相关问题