使用构造函数版本时未调用Laravel中间件终止

时间:2018-08-28 00:55:58

标签: php laravel

Laravel版本:5.1.46

routes.php

Route::get('/rocha', 'RochaController@index');

Kernel.php

protected $routeMiddleware = [
        'auth' => \App\Http\Middleware\Authenticate::class,
        'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
        'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
        'Age' => \App\Http\Middleware\AgeMiddleware::class,
        'Role' => \App\Http\Middleware\RoleMiddleware::class,
    ];

RochaController.php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

use App\Http\Requests;
use App\Http\Controllers\Controller;

class RochaController extends Controller
{

    public function __construct() {
        $this->middleware('Role');
    }
    public function index() {
        echo '<br>Hi I am index';
    }
}

RochaMiddleware.php

namespace App\Http\Middleware;
use Closure;

class RoleMiddleware
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        echo '<br>Hi I am middleware';
        return $next($request);
    }


    public function terminate($request, $response) {
        echo '<br>Shtting down...';
    }
}

结果:

Hi I am middleware
Hi I am index

当我通过控制器的构造函数$this->middleware('Role')在控制器内部使用中间件时,不会调用terminate()函数。当我切换代码以取出控制器中的构造函数并将路由更改为以下内容时,将调用terminate()函数:

Route::get('/rocha', [
    'middleware' => 'Role',
    'uses' => 'RochaController@index'
]);

结果:

Hi I am middleware
Hi I am index
Shtting down...

为什么构造函数版本($this->middleware('Role'))阻止调用terminate()函数?

为什么路由版本有效,而调用terminate()函数却与此相反?

1 个答案:

答案 0 :(得分:0)

  

如果您在中间件上定义了终止方法,则在准备将响应发送到浏览器后,将自动调用该方法。

来自terminable-middleware

我认为您误解了terminate方法的用法。 Laravel实际上调用了terminate方法,但是浏览器不会显示terminate的输出。因为响应已发送到浏览器。

您可以使用此terminate方法来测试呼叫是否成功。

public function terminate($request, $response)
{
    file_put_contents(__DIR__ . '/1.txt', 'hello terminate');
}

顺便说一句,我正在测试您的代码,它总是输出:

Hi I am middleware
Hi I am index

我还想知道为什么您可以获得Shtting down...

以上是我所了解的全部。对不起,我的英语不好。