Laravel自定义控制台命令调用所有其他自定义命令的构造函数



我在app/console/Kernel.php中注册了一组控制台命令。我的Kernel.php看起来像

<?php
namespace AppConsole;
use IlluminateConsoleSchedulingSchedule;
use IlluminateFoundationConsoleKernel as ConsoleKernel;
class Kernel extends ConsoleKernel
{
    /**
     * The Artisan commands provided by your application.
     *
     * @var array
     */
    protected $commands = [
        CommandsConsoleCommand1::class,
        CommandsConsoleCommand2::class
    ];
    /**
     * Define the application's command schedule.
     *
     * @param  IlluminateConsoleSchedulingSchedule $schedule
     *
     * @return void
     */
    protected function schedule(Schedule $schedule)
    {
        // Some code
    }
}

控制台命令类的结构看起来像

<?php namespace AppConsoleCommands;
use IlluminateConsoleCommand;
use Dependancy;
class ConsoleCommand1 extends Command
{
    protected $signature = ‘console_command_1’;
    protected $description = ‘This is the description’;
    private $dependancy;
    public function __construct(Dependancy $dependancy)
    {
        parent::__construct();
        $this->dependancy = $dependancy;
    }
    public function handle()
    {
        // Some code
    }
}

现在的问题是,每当我执行列表中的任何控制台命令时,另一个命令的构造函数也会与实际执行的命令一起执行。

例如,如果我执行"php artisan console_command_1",则"php artist console_ccommand_1"one_answers"php artison console_compand_2"的构造函数都将被执行,反之亦然。实际上,我只想调用"实际执行的artisan命令"的构造函数。

这是Laravel控制台命令的设计方式,还是我做错了什么?非常感谢您的帮助。

是的,不幸的是,这是Laravel确定手工命令是否存在的唯一方法。以下是运行命令时发生的两件主要事情:

1.运行控制台命令时,入口点是位于项目根目录中的artisan文件。这将创建一个内核实例,并在其上调用handle方法,同时传递接收到的参数(即:artisan命令名和为其传递的任何其他参数)。

2.内核的handle方法将运行artisan命令,为此,它需要一个控制台应用程序实例(内部标识为Artisan),该实例需要调用resolveCommands来创建命令列表,以便检查当前命令名是否有效。该方法将为向内核注册的每个命令(您定义的命令以及从ArtisanServiceProvider加载的所有默认命令)make一个新的实例。


实际上,因为在Kernel中,您通过类名引用来注册命令:

CommandsConsoleCommand1::class

命令名是该类的受保护属性:

protected $signature = ‘console_command_1’;

从类中获取命令名的唯一可能方法是创建该类的实例,因此将调用所有构造函数来创建整个命令列表。

最新更新