laravel中间件使用

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']);
相关文章
相关标签/搜索