Laravel 9 中基于用户角色字段(role)保护路由的完整实践指南

本文详解如何在 Laravel 9 中通过自定义中间件,依据 users.role 字段值(如 "Admin" 或 "Driver")精细化控制路由访问权限,实现比基础 auth 更严格的访问隔离。

本文详解如何在 Laravel 9 中通过自定义中间件,依据 `users.role` 字段值(如 "Admin" 或 "Driver")精细化控制路由访问权限,实现比基础 `auth` 更严格的访问隔离。

在 Laravel 9 中,仅使用 auth 或 verified 中间件只能确保用户已登录且邮箱已验证,但无法区分不同角色的访问能力。例如,你希望 /user/create 路由仅对 role = 'Admin' 的用户开放,而普通 Driver 用户即使已登录也应被拒绝——此时需引入角色感知型中间件(Role-aware Middleware)

✅ 步骤一:创建自定义中间件

运行 Artisan 命令生成中间件:

php artisan make:middleware IsAdmin

编辑 app/Http/Middleware/IsAdmin.php,完善 handle 方法逻辑(注意添加空值防护与 HTTP 响应适配):

<?php

namespace App\Http\Middleware;

use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Redirect;

class IsAdmin
{
    public function handle(Request $request, Closure $next)
    {
        // 确保用户已认证(避免 $request->user() 为 null)
        if (! $request->user()) {
            return Redirect::route('login')->with('error', '请先登录以继续操作。');
        }

        // 检查 role 字段是否为 'Admin'
        if ($request->user()->role !== 'Admin') {
            abort(403, '您没有权限执行此操作。');
        }

        return $next($request);
    }
}

? 提示:使用 abort(403) 可触发 Laravel 默认的 403 Forbidden 响应(配合 resources/views/errors/403.blade.php 自定义页面),比返回 JSON 更符合 Web 路由场景;若用于 API,则可改用 response()->json(..., 403)。

✅ 步骤二:注册并应用中间件

Laravel 9 默认已自动发现中间件,无需手动在 app/Http/Kernel.php 中注册(除非需全局或分组使用)。直接在路由中链式调用即可:

// routes/web.php
Route::middleware(['auth', 'verified'])->group(function () {
    Route::get('/users', App\Http\Livewire\User\Index::class)->name('users.index');
    Route::get('/user/{user}/edit', App\Http\Livewire\User\Edit::class)->name('user.edit');

    // ✅ 仅 Admin 可访问创建页
    Route::get('/user/create', App\Http\Livewire\User\Create::class)
        ->middleware(IsAdmin::class)
        ->name('user.create');
});

你也可以将多个中间件组合使用(顺序敏感):

->middleware(['auth', 'verified', IsAdmin::class])

✅ 进阶建议:提升可维护性与扩展性

⚠️ 注意事项

通过以上方式,你就能在 Laravel 9 中安全、清晰、可扩展地实现基于数据库字段的角色级路由保护,真正践行“最小权限原则”。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。