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


How to save/redirect output from Laravel Artisan command?

我在一个路由中使用Artisan::call(),并希望将命令输出保存到一个变量中。

有什么方法可以捕获artisan命令生成的STDOUT和STDERR吗?

这是一种方法:

use Symfony'Component'Console'Output'BufferedOutput;
Route::get('/test', function()
{
    $output = new BufferedOutput;
    Artisan::call('list', array(), $output);
    return $output->fetch();
});

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

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

似乎之前的答案在Laravel 5.2中不再有效(不确定5.1)您现在可以使用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);

我有一个独特的解决方案,对我来说效果很好在我所有其他命令扩展的基本命令类中,我重载了输出函数,然后如果需要,我可以在任何扩展命令中再次重载它们。。。很明显,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);
}