中间件
HTTP 中间件提供了为过滤进入应用的 HTTP 请求提供了一套便利的机制。例如,Laravel 内置了一个中间件来验证用户是否经过授权,如果用户没有经过授权,中间件会将用户重定向到登录页面,否则如果用户经过授权,中间件就会允许请求继续往前进入下一步操作。
当然,除了认证之外,中间件还可以被用来处理更多其它任务。比如:CORS中间件可以用于为离开站点的响应添加合适的头(跨域);日志中间件可以记录所有进入站点的请求。
Laravel框架自带了一些中间件,包括维护模式、认证、CSRF保护中间件等等。所有的中间件都位于 app/Http/Middleware 目录。
这是手册上对中间件的解释。我是这么理解中间件的:比如学校的门卫,学生上课是不允许外出的,如果有人外出,如果是学生门卫是不会放他出去,如果是老师,就可以放行。如果外来的人非本校学生或老师,是不可以进来的。所以说门卫就相当于一个中间件,用来检验这个人是不是有进出的权限,当然也会记录日志。
中间件的创建:
运行cmd,在项目存放目录下,执行php artisan make:middleware 中间件的名字
成功后会在项目 app/http/middleware 多了一个你刚创建的中间件文件。
我将$path这个路径保存,然后注册,在App\Http\Kernel下,分为全局注册和路由注册
添加这行,完成全局注册,然后我们随意访问一个路由,在public下查看contents.log这个文件就能看到请求的路径信息。
中间件还有一个路由注册,全局注册一般用来记录日志,路由注册一般用来进行限制条件。比如登陆
这时,如果没有uid的话,访问demos路由,那么会跳转到 登陆页面。因为有中间件的限制。(这里的login相当于起一个别名)路由别名也可以这么去写。