• laravel中间件-----------middleware


    middleware中间件

    是访问到达服务器后在被对应的路由处理之前所经过的一层过滤层,故称中间件。

    中间件是存放在apphttpmiddleware中,需要定一个 handle 处理方法,在handle中当处理完后,可以进行重定向,也可以使用 $next() 闭包函数执行之前的业务逻辑操作

    第一步 使用artisan生成中间件

    php artisan make:middleware testMiddleware

    生成apphttpmiddleware estMiddleware.php中间件

    <?php
    
    namespace AppHttpMiddleware;
    
    use Closure;
    
    class testMiddleware
    {
      中间件默认包含两个参数包含请求信息的$request和闭包函数$next
      $next可以继续执行之前的逻辑操作
      $request包含请求的信息
    public function handle($request, Closure $next) { // 处理请求      //执行业务操作 return $next($request); } }

    中间件可以加入其他参数

    <?php
    
    namespace AppHttpMiddleware;
    
    use Closure;
    
    class RoleMiddleware
    {
        public function handle($request, Closure $next, $parameter)
        {
        当age大于18时将参数写入文本
    if($request -> input('age') > 18) {   file_put_contents('testMiddlewareHandle.txt', $parameter);   }   return $next($request);   } }

    其他中间件参数需要使用 : 来分割  多个参数应当用逗号隔开

    Route::get('testMiddleware/{id}', ['middleware' => 'TestMiddleware:this is MiddlewareValue', 
    function($id){ file_put_contents('testRoute.txt', $id); }]); 当访问testMiddle时会经过中间件TestMiddlewarephp中的handle函数处理,函数中的$parameter被赋值
    'this is MiddlewareValue'

    除了middleware属性指定中间件,也可使用middleware链式指定中间件

    Route::get('/', ['middleware' => ['first', 'second'], function () {
        //
    }]);
    链式方法
    Route::get('/', function () { // }])->middleware(['first', 'second']);

    当访问http://localhost/testMiddleware/Route?age=19,public目录下会生成两个文件分别为testRoute.txt和testMiddlewareHandle.txt

    第二步 注册中间件

    设计好中间件后需要注册中间件,可以在 apphttpkernel.php 中注册全局的中间件$middleware

    protected $middleware = [
            IlluminateFoundationHttpMiddlewareCheckForMaintenanceMode::class,
         ];

    也可以注册局部路由中间件

    protected $routeMiddleware = [
        'auth' => AppHttpMiddlewareAuthenticate::class,
        'auth.basic' => IlluminateAuthMiddlewareAuthenticateWithBasicAuth::class,
        'guest' => AppHttpMiddlewareRedirectIfAuthenticated::class,
        'test' => AppHttpMiddlewareTestMiddleware::class,
    ];

    中间件处理顺序及可终止中间件

    对于一个请求,需要中间件进行其他的操作对其处理,可以在操作之前或者之后进行处理

    可以在$next()之前或者之后进行处理业务逻辑也可以 redirect() -> route('route')进行重定向
    public
    function handle($request, Closure $next) { if (condition) { // 执行动作 } $response = $next($request); 请求处理 if (condition) { // 执行动作 } return $response; }

    可终止中间件

    可以终止中间件是在相应已经结束之后进行的操作,加上一个 terminate 方法,

    terminate方法含有两个参数:$request $response,  当使用可终止中间件需要将其注册进$middleware中

        protected $middleware = [
            IlluminateFoundationHttpMiddlewareCheckForMaintenanceMode::class,
            AppHttpMiddlewareTestMiddleware::class,
        ];
    <?php
    
    namespace AppHttpMiddleware;
    
    use Closure;
    
    class RoleMiddleware
    {
        public function handle($request, Closure $next)
        {
                 ....
          return $next($request);
      }
    
        public function terminate($request, $response)
        {
            file_put_contents("resuest.txt", $request);
            file_put_contents("response.txt", $response);
        }
    
    }
    对于任何的请求都会执行terminat方法,也不要指定路由的中间层为 全局中间层 不然会报错 class not exist
  • 相关阅读:
    Android系统的Binder机制之一——Service Manager
    Android系统的Binder机制之二——服务代理对象(1)
    电子书
    [ 具体数学 ] 1:递归式与封闭式
    线段树封装
    实验1——顺序表的合并
    配置终端VIM 文件
    编译原理:实验二、集合与线性表操作
    括号匹配检验
    Problem B: KMP算法综合应用余庆
  • 原文地址:https://www.cnblogs.com/yangxunwu1992/p/5399968.html
Copyright © 2020-2023  润新知