什么是中间件?
所谓中间件是指提供在请求和响应之间的,能够截获请求,并在其基础上进行逻辑处理,与此同时能够完成请求的响应或传递到下一个中间件的代码。
首先按照用途列举一下常见的中间件:
前置中间件:
cookie验证:验证用户的cookie
用户角色验证:定义不同的用户角色并验证
用户权限验证:配置不同的用户权限,并验证
安全相关,如CSRF校验:CSRF校验中间件
http方法过滤:过滤特定的GET POST请求
http或者page cache:对指定路径的页面进行缓存
跨域中间件:不用在nginx配置,而是通过框架的方式,针对某些域名或某些请求,提供跨域的服务。
后置中间件:
共同数据输出:针对统一业务的公共数据,在后置中统一输出
更新日志
创建中间件
php artisan make:middleware [middleware name]
编写中间件代码
<?php
namespace App\Http\Middleware;
use Closure;
class Test
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
//在请求之前 做一些操作
......
$response = $next($request);
//next 下面在响应之后 做一些操作
......
return $response;
}
}
将上述中间件注册到 app/Http/kernel.php 的 $routeMiddleware 属性中:
protected $routeMiddleware = [
... // 其他中间件
'test' => \App\Http\Middleware\Test::class,
];;
使用中间件 在 /routes/web.php 或 api.php
Route::group(['middleware' => ['test'],'prefix'=>'admin','namespace'=>'Admin'],function (){
//你的路由
});
中间件和构造函数的执行顺序为
构造函数–中间件
之前有PHPer想在中间件中验证用户身份,但是在构造函数中直接检查登陆态,这就是执行顺序搞错了,会获取不到user
参考:https://blog.csdn.net/weixin_33752045/article/details/85995178