Laravel5 自定义路由中间件的使用
创建中间件
创建一个中间件,用于判断用户是否进行了“实名认证”。如果验证过,则通过;未验证,则返回提示信息。
首先使用指令
php artisan make:middleware CheckRealname
这会在 App\Http\Middleware命名空间下新建一个类文件 CheckRealname.php。
下面我们在类文件内填充代码。
<?phpnamespace App\Http\Middleware;use Closure;class CheckRealname{ /** * 处理传入的请求,假设用户授权登录 * * @param \Illuminate\Http\Request $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)
继续后面的逻辑处理。
注册中间件
完成中间件的类代码后,我们需要注册到 路由中间件,并让系统赋予全局可访问的方式。
在文件 App\Http\Kernel.php 内添加一下内容。
// 在 App\Http\Kernel 类中... protected $routeMiddleware = [ 'auth' => \App\Http\Middleware\Authenticate::class, 'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class, 'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class, 'cache.headers' => \Illuminate\Http\Middleware\SetCacheHeaders::class, 'can' => \Illuminate\Auth\Middleware\Authorize::class, 'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class, 'signed' => \Illuminate\Routing\Middleware\ValidateSignature::class, 'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class, 'verified' => \Illuminate\Auth\Middleware\EnsureEmailIsVerified::class, // 验证是否实名认证 'user.realname' => \App\http\Middleware\CheckRealname::class, ];
这样系统内就可以在路由控制内调用该中间件用于验证了。
调用中间件
调用中间件在路由规则内书写。类似下面这样的写法:
Route::get('user/profile', function () { // 逻辑代码,可直接执行 })->middleware('auth', 'user.realname');
除了使用路由中间件名字的方式,还可以使用使用中间件类,如下:
Route::get('user/profile', function () { // 逻辑代码,可直接执行 })->middleware(CheckRealname::class);
需要注意的是,在头部 use 引用中,将类 CheckRealname 通过命名空间引入。
评论 (0)