laravel内置了一个中间件来验证用户是否通过认证,若是用户没有通过认证,中间件会将用户重定向到登陆页面,不然若是用户通过认证,中间件就会容许请求继续往前进入下一步操做。php
固然,除了认证以外,中间件还能够被用来处理更多其它任务。好比:CORS 中间件能够用于为离开站点的响应添加合适的头(跨域);日志中间件能够记录全部进入站点的请求。laravel
Laravel框架自带了一些中间件,包括认证、CSRF 保护中间件等等。全部的中间件都位于 app/Http/Middleware
目录。跨域
中间是请求前仍是请求后执行取决于中间件自己,如下中间件会在请求处理前执行一些任务:session
1 <?php 2 3 namespace App\Http\Middleware; 4 5 use Closure; 6 7 class Common 8 { 9 10 public function handle($request, Closure $next) 11 { 12 // 执行动做 13 14 if(!$request->session()->has('huser')){ 15 return redirect("login/index"); 16 } 17 return $next($request); 18 19 20 } 21 }
而下面这个中间件则会在请求处理后执行其任务:app
1 <?php 2 3 namespace App\Http\Middleware; 4 5 use Closure; 6 7 class Common 8 { 9 10 public function handle($request, Closure $next) 11 { 12 $response = $next($request); 13 14 // 执行动做 15 if(!$request->session()->has('huser')){ 16 return redirect("login/index"); 17 } 18 19 return $response; 20 21 22 23 } 24 }
1 Route::get('/',function(){ 2 return redirect('home/index'); 3 })->middleware('common'); 4 5 6 7 Route::group(['middleware' => ['common']], function() { 8 Route::controller("db","DataBaseController"); 9 }); 10 11 12 Route::controller("home","HomeController",['middleware'=>'common']);