Laravel中间件用于处理HTTP请求与响应,可实现权限控制、日志记录等通用逻辑。通过php artisan make:middleware CheckAge命令生成中间件,位于app/Http/Middleware目录,核心为handle方法,接收请求对象和$next回调,可在前后插入前置或后置逻辑。中间件需注册使用,分为三种方式:1. 全局中间件,在app/Http/Kernel.php的$middleware属性中注册,作用于所有请求;2. 路由中间件,在$routeMiddleware数组中定义别名并绑定类,如'check.age' => \App\Http\Middleware\CheckAge::class,再在路由中通过->middleware('check.age')应用;3. 中间件分组,将多个中间件组合成组(如web、api),便于批量调用。典型应用场景包括权限检查(如判断用户是否有编辑权限)、维护模式控制(非管理员重定向至维护页)、请求日志记录(前后记录URL和状态码)以及防止表单重复提交(校验Token)。中间件支持参数传递,例如role:admin可向handle($request, $next, $role)传参,多个参数用逗号分隔。执行顺序按注册顺序正向执行,响应时逆序返回,正确
在Laravel中,中间件是处理HTTP请求和响应的强有力工具。它位于用户请求与应用逻辑之间,可用于过滤、验证、记录日志、权限控制等操作。通过中间件,你可以优雅地实现跨多个路由的通用逻辑。
使用Artisan命令可以快速生成中间件:
php artisan make:middleware CheckAge该命令会在app/Http/Middleware目录下生成一个名为CheckAge.php的文件。内容结构如下:
namespace App\Http\Middleware;
use Closure;
class CheckAge
{
public function handle($request, Closure $next)
{
if ($request->age < 18) {
return redirect('home');
}
return $next($request);
}
}
其中handle方法接收请求对象和下一个中间件回调$next。你可以在调用$next($request)前后插入逻辑,实现“前置”或“后置”处理。
中间件需要注册后才能使用,分为全局中间件、路由中间件和分组中间件三种方式。
1. 全局中间件
在app/Http/Kernel.php的$middleware属性中添加,会作用于所有请求。
2. 路由中间件
在Kernel.php的$routeMiddleware数组中注册:
'check.age' => \App\Http\Middleware\CheckAge::class,
然后在路由中使用:
Route::get('/dashboard', function () {
//
})->middleware('check.age');
3. 中间件分组
可将多个中间件组合为一组,便于复用:
// 在 Kernel.php 中
protected $middlewareGroups = [
'web' => [
\App\Http\Middleware\EncryptCookies::class,
\Illuminate\Session\Middleware\StartSession::class,
// ...
],
];
默认web和api组已内置,可通过middleware('web')应用整组中间件。
Laravel中间件适用于多种常见业务场景:
权限检查
判断用户是否有访问某页面的权限:
public function handle($request, Closure $next)
{
if (! auth()->user()?->hasPermission('edit-posts')) {
abort(403, '无权访问');
}
return $next($request);
}
维护模式控制
临时关闭某些功能路径:
if (config('app.maintenance_mode') && ! $request->user()?->isAdmin()) {
return redirect('/maintenance');
}
日志记录
记录请求信息用于调试或监控:
Log::info('Request started: ' . $request->url()); $response = $next($request); Log::info('Response sent: ' . $response->getStatusCode()); return $response;
防止重复提交
利用Token机制限制表单重复提交:
if (session('form_token') !== $request->input('token')) {
return back()->withErrors('非法请求');
}
中间件支持接收额外参数。例如定义一个检查用户角色的中间件:
public function handle($request, Closure $next, $role)
{
if (! $request->user() || $request->user()->role !== $role) {
return redirect('home');
}
return $next($request);
}
注册后在路由中使用:
middleware('role:admin')
多个参数可用逗号分隔:middleware('role:editor,publisher')。
基本上就这些。Laravel中间件机制灵活且易于扩展,合理使用能显著提升代码可维护性和安全性。不复杂但容易忽略的是中间件执行顺序——按注册顺序从前到后执行,返回响应时则逆序回传。掌握这一点有助于避免逻辑错乱。
# php
# laravel
# cookie
# app
# 工具
# session
# ai
# 路由
# 状态码
# laravel中间件
# red
# 中间件
# Token
# class
# 对象
# http
# 多个
# 你可以
# 组中
# 三种
# 表单
# 回调
# 作用于
# 的是
# 适用于
# 会在
相关文章:
如何访问已购建站主机并解决登录问题?
如何在IIS中新建站点并解决端口绑定冲突?
建站之星代理商如何保障技术支持与售后服务?
如何快速搭建高效服务器建站系统?
武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?
如何高效利用亚马逊云主机搭建企业网站?
高性价比服务器租赁——企业级配置与24小时运维服务
专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?
深圳网站制作案例,网页的相关名词有哪些?
如何在七牛云存储上搭建网站并设置自定义域名?
如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
网站制作企业,网站的banner和导航栏是指什么?
如何通过远程VPS快速搭建个人网站?
网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?
如何做网站制作流程,*游戏网站怎么搭建?
如何制作算命网站,怎么注册算命网站?
如何快速搭建响应式可视化网站?
整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?
C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换
如何挑选优质建站一级代理提升网站排名?
如何通过虚拟主机快速完成网站搭建?
黑客如何利用漏洞与弱口令入侵网站服务器?
javascript中的try catch异常捕获机制用法分析
宝塔建站后网页无法访问如何解决?
网站建设制作需要多少钱费用,自己做一个网站要多少钱,模板一般多少钱?
html制作网站的步骤有哪些,iapp如何添加网页?
C++如何使用std::optional?(处理可选值)
英语简历制作免费网站推荐,如何将简历翻译成英文?
独立制作一个网站多少钱,建立网站需要花多少钱?
宝塔建站教程:一键部署配置流程与SEO优化实战指南
如何在局域网内绑定自建网站域名?
如何在新浪SAE免费搭建个人博客?
如何通过cPanel快速搭建网站?
如何通过智能用户系统一键生成高效建站方案?
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
如何规划企业建站流程的关键步骤?
如何在景安云服务器上绑定域名并配置虚拟主机?
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
如何用5美元大硬盘VPS安全高效搭建个人网站?
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
利用JavaScript实现拖拽改变元素大小
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
如何通过可视化优化提升建站效果?
网站图片在线制作软件,怎么在图片上做链接?
国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?
如何通过西部建站助手安装IIS服务器?
建站之星下载版如何获取与安装?
临沂网站制作公司有哪些,临沂第四中学官网?
C++用Dijkstra(迪杰斯特拉)算法求最短路径
*请认真填写需求信息,我们会在24小时内与您取得联系。