本文实例讲述了laravel框架中间件简单使用方法。分享给大家供大家参考,具体如下:

laravel内置了一个中间件来验证用户是否经过认证,如果用户没有经过认证,中间件会将用户重定向到登录页面,否则如果用户经过认证,中间件就会允许请求继续往前进入下一步操作。

当然,除了认证之外,中间件还可以被用来处理更多其它任务。比如:cors 中间件可以用于为离开站点的响应添加合适的头(跨域);日志中间件可以记录所有进入站点的请求。

laravel框架自带了一些中间件,包括认证、csrf 保护中间件等等。所有的中间件都位于 app/http/middleware目录。

中间是请求前还是请求后执行取决于中间件本身,以下中间件会在请求处理前执行一些任务

<?php
namespace app\http\middleware;
use closure;
class testmiddle
{
  public function handle($request, closure $next)
  {
    // 执行动作
    if(!$request->session()->has('huser')){
      return redirect("login/index");
    }
    return $next($request);
  }
}

而下面这个中间件则会在请求处理后执行其任务:

<?php
namespace app\http\middleware;
use closure;
class testmiddle
{
  public function handle($request, closure $next)
  {
    $response = $next($request);
    // 执行动作
    if(!$request->session()->has('huser')){
      return redirect("login/index");
    }
    return $response;
  }
}

中间件可以自己在编辑器里面新建对应类生成,也可用命令生成

php artisan make:middleware testmiddle

此时,laravel的app\http\middleware\目录就会多一个testmiddle.php的中间件文件

此时中间件还不能直接使用,必须把它注册到我们的laravel中,如下

只需在 app/http/kernel.php 类(3个属性,对应里面加入,我有时用路由的)

'testmiddle' => \app\http\middleware\testmiddle::class,

分配中间件到路由,下面介绍三种方式

route::get('/',function(){
  return redirect('home/index');
})->middleware('testmiddle');
route::group(['middleware' => ['testmiddle']], function() {
  route::controller("db","databasecontroller");
});
route::controller("home","homecontroller",['middleware'=>'testmiddle']);