使用Artisan命令生成CheckRole中间件;2. 在handle方法中添加角色验证逻辑,非管理员重定向至首页;3. 将中间件注册到Kernel.php的$routeMiddleware数组并设置别名;4. 在路由中通过middleware方法应用该中间件;5. 启动服务并测试不同用户访问权限控制效果。

如果您希望在 laravel 应用中控制请求的访问流程,例如验证用户角色或检查请求来源,可以通过创建自定义中间件来实现。以下是创建和注册自定义中间件的具体步骤:
本文运行环境:macBook Pro,macOS Sonoma
一、生成自定义中间件类
使用 Artisan 命令行工具可以快速生成中间件骨架文件。该命令会在 app/http/Middleware 目录下创建对应的 PHP 文件。
1、打开终端并进入您的 Laravel 项目根目录。
2、执行以下命令创建名为 CheckRole 的中间件:
php artisan make:middleware CheckRole
二、编写中间件逻辑
在生成的中间件文件中添加具体的处理逻辑。中间件的核心是 handle 方法,它接收请求对象和下一个闭包函数。
1、打开 app/Http/Middleware/CheckRole.php 文件。
2、在 handle 方法中添加角色判断逻辑,例如仅允许管理员访问:
if ($request->user() && $request->user()->role !== ‘admin’) { return redirect(‘/home’); }
3、确保在方法末尾调用 $next($request) 以继续请求流程。
三、注册中间件到应用
新创建的中间件需要注册到 Laravel 内核中才能生效。可以选择注册为全局中间件或路由中间件。
1、若要作为全局中间件,打开 app/Http/Kernel.php 文件,并将中间件类添加到 $middleware 数组中。
2、若仅用于特定路由,将其添加到 $routeMiddleware 数组,并指定一个别名,如:
‘role’ => AppHttpMiddlewareCheckRole::class,
四、在路由中使用中间件
通过路由配置启用已注册的中间件,从而对指定请求路径施加访问限制。
1、打开 routes/web.php 或其他路由文件。
2、在定义路由时使用 middleware 方法绑定中间件,例如:
Route::get(‘/admin’, [AdminController::class, ‘index’])->middleware(‘role’);
五、测试中间件功能
验证中间件是否按预期工作,可通过模拟不同用户身份发起请求进行测试。
1、启动本地开发服务器:
php artisan serve
2、使用浏览器或 postman 访问受保护的路由,确认非管理员用户被正确重定向。
以上就是laravel怎么创建一个自定义中间件_laravel自定义中间件创建方法的详细内容,更多请关注php中文网其它相关文章!