先谈一谈中间件的使用场景,比如路由转到一张页面,我们需要记录用户的cookie,或者检测用户的访问权限,这些操作如果全写在控制器里是不合适的,因为随着业务的扩充,控制器里的业务逻辑会越来越臃肿,难以维护,所以,不同的操作,我们分别写在各自的中间件里。我们使用artisan命令行来创建一个中间件。
php artisan make:middleware MyMiddleware
中间件的php文件都放在了目录appHttpMiddleware下,大家应该注意到,中间件Middleware和控制器Controller文件夹都在Http文件夹下。
<?php
namespace AppHttpMiddleware;
use Closure;
class MyMiddleware
{
/**
* Handle an incoming request.
*
* @param IlluminateHttpRequest $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 = [
IlluminateFoundationHttpMiddlewareCheckForMaintenanceMode::class,
AppHttpMiddlewareMyMiddleware::class,
];
第二种,Kernel.php的$routeMiddleware数组中注册,这种注册方式适用于部分指定页面才可以启动这个中间件。
protected $routeMiddleware = [
'auth' => AppHttpMiddlewareAuthenticate::class,
'auth.basic' => IlluminateAuthMiddlewareAuthenticateWithBasicAuth::class,
'guest' => AppHttpMiddlewareRedirectIfAuthenticated::class,
'throttle' => IlluminateRoutingMiddlewareThrottleRequests::class,
'mymiddleware'=>AppHttpMiddlewareMyMiddleware::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';
}]);