我在我的一個路由中使用了Artisan::call()
,並希望將命令輸出保存到變量中。如何保存/重定向Laravel Artisan命令的輸出?
有什麼方法可以捕獲artisan命令生成的STDOUT和STDERR嗎?
我在我的一個路由中使用了Artisan::call()
,並希望將命令輸出保存到變量中。如何保存/重定向Laravel Artisan命令的輸出?
有什麼方法可以捕獲artisan命令生成的STDOUT和STDERR嗎?
這是一個辦法:
use Symfony\Component\Console\Output\BufferedOutput;
Route::get('/test', function()
{
$output = new BufferedOutput;
Artisan::call('list', array(), $output);
return $output->fetch();
});
當然,只要看看Illuminate\Foundation\Artisan::call
的方法定義。它接受第三個參數,您可以使用它來控制使用的輸出流。例如:
$outputStream = new \Symfony\Component\Console\Output\StreamOutput(
fopen('php://output', 'w')
);
ob_start();
Artisan::call('routes', [], $outputStream);
$commandOutput = ob_get_clean();
謝謝,我選擇另一個,因爲它更乾淨。但是你的方法同樣適用。 +1了 – Dave
似乎以前的答案不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);
這工作。但在我的具體情況下,我遇到了一個問題。你可以看看這個線程:http://stackoverflow.com/questions/20113385/artisan-output-buffer-does-not-contain-all-output – Dave
我有這個相同的問題,但這工作得很好。 – enchance