前言
Laravel5中我们处理request请求,中间会有很多环节。本文所说的中间件,位于路由和控制器之间,起到过滤和筛选请求的作用。
为什么不放到“表单验证”里呢?
因为有些请求,我们可能不太理会表单内容,或者想要在表单数据注入控制器方法之前,就进行拦截,那么,中间件无疑是一个好的选择。
创建中间件
下面示例,创建一个中间件,用于判断用户是否进行了“实名认证”。如果验证过,则通过;未验证,则返回提示信息。
首先使用指令
php artisan make:middleware CheckRealname
这会在 AppHttpMiddleware命名空间下新建一个类文件 CheckRealname.php。
下面我们在类文件内填充代码。
<?phpnamespace AppHttpMiddleware;use Closure;class CheckRealname{/*** 处理传入的请求,假设用户授权登录** @param IlluminateHttpRequest $request* @param Closure $next* @return mixed*/public function handle($request, Closure $next){if (!auth()->user()->is_realname) {return response()->json(['code'=>0,'msg'=>'请先进行实名验证']);}return $next($request);}}
上述代码根据用户授权状态获取用户实例,并查找字段is_realname,判断用户的“实名验证”状态。如果没有验证,使用
response()->json()
构造一个JSON响应数据返回给客户端。那么接下来的请求都不需要进行。
如果是验证过的用户,使用
return $next($request)
继续后面的逻辑处理。
注册中间件
完成中间件的类代码后,我们需要注册到 路由中间件,并让系统赋予全局可访问的方式。
在文件 AppHttpKernel.php 内添加一下内容。
// 在 AppHttpKernel 类中...protected $routeMiddleware = ['auth' => AppHttpMiddlewareAuthenticate::class,'auth.basic' => IlluminateAuthMiddlewareAuthenticateWithBasicAuth::class,'bindings' => IlluminateRoutingMiddlewareSubstituteBindings::class,'cache.headers' => IlluminateHttpMiddlewareSetCacheHeaders::class,'can' => IlluminateAuthMiddlewareAuthorize::class,'guest' => AppHttpMiddlewareRedirectIfAuthenticated::class,'signed' => IlluminateRoutingMiddlewareValidateSignature::class,'throttle' => IlluminateRoutingMiddlewareThrottleRequests::class,'verified' => IlluminateAuthMiddlewareEnsureEmailIsVerified::class,// 验证是否实名认证'user.realname' => ApphttpMiddlewareCheckRealname::class,];
这样系统内就可以在路由控制内调用该中间件用于验证了。
调用中间件
调用中间件在路由规则内书写。类似下面这样的写法:
Route::get('user/profile', function () {// 逻辑代码,可直接执行})->middleware('auth', 'user.realname');
除了使用路由中间件名字的方式,还可以使用使用中间件类,如下:
Route::get('user/profile', function () {// 逻辑代码,可直接执行})->middleware(CheckRealname::class);
需要注意的是,在头部 use 引用中,将类 CheckRealname 通过命名空间引入。
结语
好了,上面就是laravel自定义中间件的使用过程,相信大家可以很快掌握。
自定义的中间件可以为我们处理更为复杂的逻辑,也使控制器代码更为整洁,不会把所有逻辑都堆在控制器内,维护起来臃肿冗余。
Happy coding :-)
【本文由 @程序员小助手 发布,持续分享编程故事,欢迎关注】