我使用Artisan
通过命令行调用Laravel 5 Route
。我按照这篇文章中的说明创建了一个命令行控制器:Call laravel controller via command line。
当我在网络浏览器中导航到此路线时,我没有收到任何错误。此路由执行API调用,并使用我创建的名为Laravel
的{{1}} Model
将数据插入MySQL数据库。
当我可以从CLI调用我的路由时,如下:
Ticker
我收到$ php artisan route:call /d17059dfce4c09ef5e437b1d9455f7c6
错误(其中Laravel
是路由调用的控制器中执行的第一个SQL命令,truncate 'tickers'
是数据库中的表) ,陈述:
tickers
因为我在通过命令行执行此路由时似乎只是收到错误,所以我认为命令行脚本SQLSTATE[HY000] [2002] No such file or directory (SQL: truncate `tickers`)
必须存在一些问题,如下所示:
App\Console\Commands\CallRoute.php
非常感谢任何有关排除或解决此错误的帮助。提前谢谢。
答案 0 :(得分:1)
您应该传递/d17059dfce4c09ef5e437b1d9455f7c6
作为选项而不是参数。它将其解释为目录。
php artisan route:call --uri=/d17059dfce4c09ef5e437b1d9455f7c6
更新命令签名以包含uri
选项:
protected $signature = 'route:call {--uri=}';
命令:
class CallRoute extends Command
{
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'route:call {--uri=}';
/**
* The console command description.
*
* @var string
*/
protected $description = 'php artsian route:call /route';
/**
* Create a new command instance.
*
* @return void
*/
public function __construct()
{
parent::__construct();
}
/**
* Execute the console command.
*
* @return mixed
*/
public function handle()
{
$request = Request::create($this->option('uri'), 'GET');
$this->info(app()->make(\Illuminate\Contracts\Http\Kernel::class)->handle($request));
}
}
答案 1 :(得分:1)
尝试看看这个问题。
PDOException SQLSTATE[HY000] [2002] No such file or directory
当我的 php-cli 与mysql的连接出现问题时我遇到了类似的问题,而我的 php-fpm 工作正常(这也可能是你为什么不这样做的原因)在浏览器中导航到此路线时出现错误)。我必须在我的php-cli配置中启用mysql pdo扩展。
只需在控制台中运行php -v
,如果您看到类似的内容:
PHP 7.2.1 (cli) (built: Jan 8 2018 23:39:24) ( NTS )
这可能意味着您必须为php-cli启用pdo支持
答案 2 :(得分:0)
也许你想说TRUNCATE TABLE tickers
?你扔掉那张桌子上的所有东西吗?
答案 3 :(得分:0)
php artisan
命令命令类的创建和对象(您创建的自定义命令)。这是为了获取可用命令和选项的列表。
您可能已添加数据库查询(truncate table tickers
)任何命令文件构造函数(__construct()
)。