首页 > 解决方案 > 只有管​​理员角色才能访问 /admin。但它不工作

问题描述

用户.php:

public function IsAdmin(){
    return $this->role=='admin';
}

Checkifadmin.php(中间件):

public function handle($request, Closure $next)
{
  if (auth()->user()->role=='admin') {
    return redirect(route('home'));
  }
  return $next($request);
}

内核.php:

在受保护的路线中

'checkifadmin' =>\App\Http\Middleware\Checkifadmin::class,

create_users_table.php

Schema::create('users', function (Blueprint $table) {
            $table->id();
            $table->string('name');
            $table->string('email')->unique();
            $table->timestamp('email_verified_at')->nullable();
            $table->string('password');
            $table->string('role')->default('customer');
            $table->rememberToken();
            $table->timestamps();
});

网页.php:

Route::get('admin',function(){
return view('layouts.admin');
})->middleware(['checkifadmin']);
Route::get('/', function () {
    return view('index');
})->name('home');
Route::get('/shop/product', function () {
    return view('shop.product');
})->name('shop.product');
Route::get('/shop/shoppingcard', function () {
    return view('shop.shoppingcard');
})->name('shop.shoppingcard');
Route::get('/shop/checkout', function () {
    return view('shop.checkout');
})->name('shop.checkout');

Auth::routes();

我的用户中有 2 个角色。客户和管理员,只有管理员应该有权访问 /admin 但由于某种原因它似乎不起作用。我已经复制并粘贴了我为这个问题所做的所有可能的代码,提前谢谢你

标签: laravelmiddlewarelaravel-6

解决方案


admin如果只允许在中间件中,则中间件应如下所示

Checkifadmin.php(中间件):

public function handle($request, Closure $next)
{
    if (auth()->user()->role !='admin') {
        return redirect(route('home'));
    }

    return $next($request);

}

然后你可以保持你的路线原样

Route::get('admin',function() {
    return view('layouts.admin');
})->middleware(['checkifadmin']);

推荐阅读