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)

发表评论