Pour les débutants de Laravel, ils ne savent peut-être pas grand-chose sur les commandes de console Artisan personnalisées de Laravel. L'article suivant partagera avec vous un exemple de création d'une commande de console Artisan personnalisée dans le framework Laravel.
1. Mise en route
Laravel fournit de puissantes commandes de console via Artisan pour gérer la logique métier non-navigateur. Pour afficher toutes les commandes Artisan dans Laravel, vous pouvez l'exécuter dans le répertoire racine du projet :
php artisan list
Le résultat correspondant est le suivant (capture d'écran partielle) :
où Nous connaissons déjà certains noms, comme créer une migration make:migration et exécuter une migration migrate, créer un modèle make:model, créer un contrôleur make:controller, etc.
Si vous souhaitez vérifier l'utilisation spécifique d'une certaine commande, par exemple, si nous voulons vérifier l'utilisation spécifique de la commande Artisan make:console, vous pouvez utiliser la commande suivante :
php artisan help make:console
Le résultat correspondant est le suivant :
2. Commande de création
En plus de fournir des commandes de console riches, Artisan nous permet également de créer via la commande make:console nos propres commandes de console. Ci-dessus, nous avons utilisé la commande help pour vérifier l'utilisation de make:console. Suivons ce chemin et découvrons : créez la commande et exécutez-la pour obtenir les différents résultats souhaités.
Nous créons d'abord la commande la plus simple pour imprimer Hello LaravelAcademy, en utilisant la commande Artisan comme suit :
php artisan make:console HelloLaravelAcademy --command=laravel:academy
où HelloLaravelAcademy est le nom de la commande, laravel:academy est la commande exécutée par la console , similaire à make:console.
Une fois l'exécution terminée, un fichier HelloLaravelAcademy.php sera généré dans le répertoire app/Console/Commands :
<?php namespace App\Console\Commands; use Illuminate\Console\Command; class HelloLaravelAcademy extends Command { /** * The name and signature of the console command. * * @var string */ protected $signature = 'laravel:academy'; /** * The console command description. * * @var string */ protected $description = 'Command description.'; /** * Create a new command instance. * * @return void */ public function __construct() { parent::__construct(); } /** * Execute the console command. * * @return mixed */ public function handle() { // } }
où $signature est le nom de la commande exécutée sur la console , $description est la description de la commande et la méthode handle est la méthode appelée lors de l'exécution de la commande.
Ensuite, nous écrivons simplement la méthode handle comme suit :
public function handle() { echo "Hello LaravelAcademy\n"; }
D'accord, la commande la plus simple a été écrite, comment l'exécuter et afficher "Bonjour" sur la console. Qu'en est-il de LaravelAcademy " ?
3. Exécutez la commande
Avant d'exécuter la commande, vous devez l'enregistrer dans l'attribut $commands d'AppConsoleKernel :
protected $commands = [ ... //其他命令类 \App\Console\Commands\HelloLaravelAcademy::class ];
Ensuite, vous pouvez exécuter la commande Artisan suivante sur la console :
php artisan laravel:academy
Le terminal affichera :
Hello LaravelAcademy
N'est-ce pas très simple ?
4. Entrées et sorties plus diversifiées
Bien sûr, le cas ci-dessus est le cas le plus simple, sans entrée ni sortie codée en dur. Dans l’environnement réel, il existe des exigences plus complexes et des entrées et sorties plus diverses. Discutons-en une par une ci-dessous.
Définir l'entrée
Comme mentionné ci-dessus, nous pouvons définir les paramètres et les options d'entrée en modifiant l'attribut $signature. Par exemple, ici, nous ajustons la chaîne après Hello ci-dessus pour. Contrôlé par les paramètres d'entrée, $signature peut être modifié comme suit :
protected $signature = 'laravel:academy {name}';
Cette définition signifie que le nom est un paramètre obligatoire. Bien sûr, des entrées de paramètres plus personnalisés sont prises en charge :
{name?} //可选参数 {name=LaravelAcademy} //默认name值为LaravelAcademyAfin d'améliorer la robustesse du programme, nous avons modifié le nom pour avoir une valeur par défaut :
protected $signature = 'laravel:academy {name=LaravelAcademy}';Parfois nous passons également certaines options lors de l'exécution de la commande, comme par exemple s'il faut afficher les signes de ponctuation ( même si cela semble de mauvais goût, c'est pour tester), alors nous pouvons modifier l'attribut $signature comme suit :
protected $signature = 'laravel:academy {name=LaravelAcademy} {--mark}';Si --mark est passé lors de l'appel de la commande, cela signifie que la valeur est vraie, sinon, c'est faux. Si la valeur de l'option est saisie via les paramètres utilisateur, $signature peut être défini comme suit :
protected $signature = 'laravel:academy {name=LaravelAcademy} {--mark=}';De cette façon, l'utilisateur peut attribuer une valeur à l'option via = lors de la transmission. l'option. Bien entendu, comme les paramètres, on peut également spécifier une valeur par défaut pour l'option :
protected $signature = 'laravel:academy {name=LaravelAcademy} {--mark=!}';
Obtenir l'entrée
Après avoir défini les paramètres d'entrée et options, comment obtenir leurs valeurs correspondantes ? Laravel nous fournit les méthodes correspondantes. Vous pouvez obtenir les valeurs des paramètres via la méthode argument d'IlluminateConsoleCommand :$name = $this->argument('name');Si la méthode argument est appelée sans paramètres, un tableau de toutes les valeurs des paramètres sera renvoyé. Vous pouvez obtenir la valeur de l'option via la méthode d'option d'IlluminateConsoleCommand :
$mark = $this->option('mark');De même, appeler la méthode d'option sans paramètres renverra un tableau de toutes les valeurs d'option. De cette façon, nous pouvons modifier la méthode handle de HelloLaravelAcademy comme suit :
public function handle() { $name = $this->argument('name'); $mark = $this->option('mark'); $string = 'Hello '.$name; if($mark) $string .= $mark; echo $string."\n"; }De cette façon, nous saisissons la commande Artisan suivante dans la console :
php artisan laravel:academyLa sortie correspondante est :
Hello LaravelAcademy!Exécutez la commande Artisan suivante :
php artisan laravel:academy Laravel --mark=?La sortie correspondante est :
Hello Laravel?
Invite de saisie
us Il est même possible pour les utilisateurs d'obtenir des paramètres d'entrée en entrant le nom dans la console. Tout d'abord, modifiez la méthode handle comme suit :public function handle() { $name = $this->ask('What do you want to say Hello?'); echo "Hello ".$name."\n"; }Saisissez ensuite php artisan laravel : académie dans le terminal. La page interactive est la suivante :
Parfois, nous choisirons de continuer ou d'abandonner selon les souhaits de l'utilisateur :
public function handle() { if($this->confirm('Do you want to continue?[y|n]')){ $this->info("Continue"); }else{ $this->error("Interrupt"); } }La sortie correspondante est :
除了让用户手动输入外,还可以使用anticipate方法实现自动完成功能:
public function handle() { $name = $this->anticipate('What is your name?', ['Laravel', 'Academy']); $this->info($name); }
当然还可以使用choice方法为用户提供选择避免手动输入,用户只需选择对应索引即可:
public function handle() { $name = $this->choice('What is your name?', ['Laravel', 'Academy']); $this->info($name); }
对应交互页面如下:
编写输出
关于输出字符串,上面我们简单使用了echo语句,其实Laravel提供了更为强大和多样化的方法:
public function handle() { $this->info("Successful!"); $this->error("Something Error!"); $this->question("What do you want to do?"); $this->comment("Just Comment it!"); }
执行php artisan laravel:academy对应输出如下:
表格
Artisan甚至可以输出表格:
public function handle() { $headers = ['Name', 'Email']; $users = \App\User::all(['name', 'email'])->toArray(); $this->table($headers, $users); }
执行php artisan laravel:academy对应输出为:
进度条
当然对于复杂耗时的命令,进度条是必不可少的,
public function handle() { $this->output->progressStart(10); for ($i = 0; $i < 10; $i++) { sleep(1); $this->output->progressAdvance(); } $this->output->progressFinish(); }
执行php artisan laravel:academy对应输出为:
5、从CLI之外调用Artisan
除了在控制台执行Artisan命令之外,还可以通过代码在别处调用Artisan命令,比如其它Artisan命令、控制器、路由或其他。
路由
在路由闭包中我们可以通过Artisan门面的call方法来调用本节创建的命令:
//在路由中调用Artisan命令 Route::get('testArtisan',function(){ $exitCode = Artisan::call('laravel:academy', [ 'name' => 'Laravel学院', '--mark' => '!' ]); });
其它Artisan命令
在一个Artisan命令中也可以调用另一个Artisan命令,还是通过call方法:
public function handle() { $this->call('inspire'); }
如果想要调用一个Artisan命令并阻止其所有输出,可以使用callSilent方法:
public function handle() { $this->callSilent('inspire'); }
除此之外,关于Artisan命令你还应该知道的是我们可以在创建的命令类的控制器或方法中注入任何依赖。这就意味着我们可以在命令类中使用注册到服务容器的所有类。
相关推荐:
Laravel框架内置的Broadcast功能如何实现与客户端实时通信
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!