如何保存/重定向 Laravel Artisan 命令的输出?

问题描述 投票:0回答:4

我在其中一条路线中使用

Artisan::call()
,并希望将命令输出保存到变量中。

有没有办法捕获artisan命令生成的STDOUT和STDERR?

php laravel laravel-4
4个回答
33
投票

这是一个方法:

use Symfony\Component\Console\Output\BufferedOutput;

Route::get('/test', function()
{
    $output = new BufferedOutput;

    Artisan::call('list', array(), $output);

    return $output->fetch();
});

10
投票

当从另一个命令内部运行一个命令时,以下是如何获取所有样式:

public function handle()
{
    Artisan::call('other:command', [], $this->getOutput());
}

8
投票

您现在可以使用

Artisan::output();

    $output = '';       
    if (!Schema::hasTable('migrations')) {
        Artisan::call('migrate:install', array());
        $output .= Artisan::output();
    }
    
    // Updates the migration, then seed the database
    Artisan::call('migrate:refresh', array('--force' => 1));
    $output .= Artisan::output();
    
    Artisan::call('db:seed', array('--force' => 1));
    $output .= Artisan::output();
    
    dd($output);

0
投票

我有一个适合我的独特解决方案 在我的所有其他命令扩展的基本 Command 类中,我重载了输出函数,然后如果需要,我可以在任何扩展命令中再次重载它们...显然 writeLogFile 是我制作的另一个自定义函数,但是您可以做任何您想做的事情想要那里

public function info($message,$verbosity = null)
{
    $this->writeLogFile($message);
    parent::info($message);
}
public function warn($message,$verbosity = null)
{
    $this->writeLogFile($message);
    parent::warn($message);
}
public function error($message,$verbosity = null)
{
    $this->writeLogFile($message);
    parent::error($message);
}
© www.soinside.com 2019 - 2024. All rights reserved.