Laravel中间件

时间:2023-03-08 19:03:51

先谈一谈中间件的使用场景,比如路由转到一张页面,我们需要记录用户的cookie,或者检测用户的访问权限,这些操作如果全写在控制器里是不合适的,因为随着业务的扩充,控制器里的业务逻辑会越来越臃肿,难以维护,所以,不同的操作,我们分别写在各自的中间件里。我们使用artisan命令行来创建一个中间件。

php artisan make:middleware MyMiddleware

中间件的php文件都放在了目录\app\Http\Middleware下,大家应该注意到,中间件Middleware和控制器Controller文件夹都在Http文件夹下。

<?php

namespace App\Http\Middleware;

use Closure;

class MyMiddleware
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
return $next($request);
}
}

这里我们只改动handle函数来举例中间件的使用

public function handle($request, Closure $next)
{
echo 'MyMiddleware is running!';
return $next($request);
}

中间件不注册是不能使用的。注册方式有以下两种,取其一即可。

第一种,Kernel.php的$middleware数组中注册,这种注册后,所有的HTTP请求都将可以启动这个中间件,特别适合用在身份认证类的功能上。

protected $middleware = [
\Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
\App\Http\Middleware\MyMiddleware::class,
];

第二种,Kernel.php的$routeMiddleware数组中注册,这种注册方式适用于部分指定页面才可以启动这个中间件。

protected $routeMiddleware = [
'auth' => \App\Http\Middleware\Authenticate::class,
'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class, 'mymiddleware'=>\App\Http\Middleware\MyMiddleware::class,
];

请注意,注册中间件,不是等于启动中间件,注册仅仅是让你能用而已,但是具体调用还是要另外写的。

如果你的View有对应的Controller,就直接在Controller里写。

class MyController extends Controller
{
public function index()
{
$this->middleware('MyMiddleware');
//你也可以继续使用其他中间件 return View('welcome');
}
}

如果路由里直接绑定了一个匿名函数,可以修改routes.php

Route::get('/index',['middleware'=>'mymiddleware',function(){
return 'hello world';
}]);