Points de base
- Phake est un outil d'automatisation PHP qui aide les développeurs à automatiser les tâches répétitives telles que la mise à jour des structures de base de données, le remplissage de la base de données, la rédaction du code CRUD, l'exécution de tests et le téléchargement de fichiers sur le serveur.
- L'utilisation de phake nécessite la création et la configuration de tâches dans un fichier Phake, similaire à GruntFile. Les tâches peuvent être exécutées séquentiellement, ont des dépendances et peuvent être regroupées.
- Phake permet de décrire les tâches et facilite la compréhension des fonctions de tâches spécifiques, en particulier lorsqu'il existe un grand nombre de tâches dans le fichier de phares.
- En faisant passer des paramètres, les tâches de phake peuvent être plus flexibles et personnaliser des tâches spécifiques. Cela se fait en déclarant les paramètres dans la fonction, puis en utilisant les paramètres pour accéder aux paramètres individuels transmis à la tâche.
En tant que développeurs, nous devons souvent effectuer des tâches répétitives telles que la mise à jour des structures de base de données, le remplissage des bases de données, la rédaction du code CRUD, l'exécution de tests et le téléchargement de fichiers sur le serveur. Ne serait-il pas préférable que ces tâches quotidiennes puissent être automatisées et se concentrer sur des problèmes plus importants (comme l'amélioration de la sécurité ou de la disponibilité de votre application)?
Phake est un outil d'automatisation écrit pour PHP qui peut vous aider avec ces tâches. Si vous connaissez Ruby, c'est essentiellement un clone de râteau. Dans cette série en deux parties, je vous guiderai à travers l'intégration de Phake dans votre flux de travail. Je vais vous guider à travers le processus d'installation, introduire quelques bases de Phake et enfin quelques exemples pratiques.
Installation
Installez Phake globalement via Composer:
composer global require 'jaz303/phake=*'
Cela permet d'accéder à Phake à partir de n'importe quel dossier sans modifier le fichier composer.json du projet.
Si vous ne pouvez pas accéder à la commande "Composer", veuillez installer le compositeur à l'échelle mondiale.
bases
Pour effectuer une tâche Phake, vous devez créer un PhakeFile. Le PhakeFile contient la configuration de la tâche à exécuter. Si vous avez déjà utilisé Grunt, PhakeFile est similaire à GruntFile.
Une note importante sur PhakeFile est que ce n'est qu'un fichier PHP, vous pouvez donc l'écrire comme vous le feriez avec un projet PHP.
Créer une tâche
Vous pouvez créer des tâches en appelant la méthode tâche (). Cette méthode prend le nom de la tâche comme le premier paramètre et la fonction à exécuter comme dernier paramètre.
<?php task('task_a', function(){ echo "Hi I'm task A!\n"; });
Vous pouvez ensuite l'exécuter avec la commande suivante:
phake task_a
Cela renverra la sortie suivante:
<code>Hi I'm task A!</code>
dépendances
Si une tâche dépend d'une autre tâche, vous pouvez fournir le nom de la tâche après la tâche principale:
<?php task('task_a', function(){ echo "Hi I'm task A!\n"; }); task('task_b', 'task_a', function(){ echo "Hi I'm task B! I need task A to execute first before I can do my thing!\n"; });
Pour exécuter des tâches dans l'ordre, il vous suffit d'appeler la tâche avec les dépendances en premier. Dans ce cas, Task_B dépend de Task_A, nous l'appelons donc en premier:
phake task_b
L'exécution de celui-ci renverra la sortie suivante:
<code>Hi I'm task A! Hi I'm task B! I need task A to execute first before I can do my thing!</code>
Vous pouvez continuer à ajouter des dépendances:
composer global require 'jaz303/phake=*'
les exécuter en appelant les tâches finales qui nécessitent le dernier appel. Dans cet exemple, la dernière chose que nous voulons exécuter est Task_C, donc nous l'appelons d'abord:
<?php task('task_a', function(){ echo "Hi I'm task A!\n"; });
Il renverra la sortie suivante:
phake task_a
Notez que l'utilisation de cette méthode qui déclare les dépendances, l'appel Task_B provoquera d'abord l'appel de Task_A. Si vous ne voulez pas que cela se produise et que vous souhaitez toujours effectuer une tâche spécifique seule sans exécuter ses dépendances en premier, vous pouvez le déclarer en utilisant la méthode suivante:
<code>Hi I'm task A!</code>
Dans l'exemple ci-dessus, nous définissons Task_A et Task_B en tant que dépendances de Task_C. Veuillez noter que la commande ici est importante. Par conséquent, la tâche suivant immédiatement la tâche principale (TASK_A) sera exécutée en premier, la tâche immédiatement suivante (Task_B) sera la seconde et la tâche principale (TASK_C) sera enfin exécutée.
Dans Phake, il existe un autre moyen de définir les dépendances: après la définition de la tâche principale, utilisez le bloc avant ou après. Dans ce cas, notre tâche principale est de manger, nous définissons donc dans sa déclaration la tâche à effectuer avant et après:
<?php task('task_a', function(){ echo "Hi I'm task A!\n"; }); task('task_b', 'task_a', function(){ echo "Hi I'm task B! I need task A to execute first before I can do my thing!\n"; });
Lorsque vous exécutez EAT, vous obtiendrez la sortie suivante:
phake task_b
Tâches de groupe
En utilisant Phake, vous pouvez également combiner les tâches associées:
<code>Hi I'm task A! Hi I'm task B! I need task A to execute first before I can do my thing!</code>
La tâche de regroupement peut être appelée en utilisant le nom de groupe que vous avez spécifié, suivi d'un côlon, puis du nom de la tâche que vous souhaitez effectuer:
<?php task('task_a', function(){ echo "I get to execute first!\n"; }); task('task_b', 'task_a', function(){ echo "Second here!\n"; }); task('task_c', 'task_b', function(){ echo "I'm the last one!\n"; });
Si vous souhaitez effectuer toutes les tâches du groupe, vous pouvez faire en sorte que la tâche finale dépend des première et deuxième tâches. Dans l'exemple suivant, la tâche finale que nous voulons effectuer est la tâche MOP_THE_FLOOR, nous le faisons donc dépendre des tâches Poison_Furniture et Wash_the_cothes:
phake task_c
Ensuite, nous appelons simplement la tâche MOP_THE_FLOOR du terminal:
<code>I get to execute first! Second here! I'm the last one!</code>
Cela appellera les tâches dans l'ordre suivant:
task('task_a', function(){ echo "I get to execute first!\n"; }); task('task_b', function(){ echo "Second here!\n"; }); task('task_c', 'task_a', 'task_b', function(){ echo "I'm the last one!\n"; });
Description Tâche
Après avoir utilisé Phake pendant un certain temps, vous pouvez accumuler de nombreuses tâches dans votre FhakeFile, il vaut donc mieux avoir une documentation. Heureusement, Phake est livré avec un utilitaire qui nous permet de décrire la fonctionnalité d'une tâche Phake spécifique. Vous pouvez appeler la méthode DESC avant que la déclaration des tâches soit décrite:
task('eat', function(){ echo "Yum!"; }); before('eat', function(){ echo "Wash your hands before you eat\n"; }); after('eat', function(){ echo "Brushy brush! brush!\n"; });
Vous pouvez ensuite énumérer les tâches disponibles dans le FhakeFile à l'aide de la commande suivante:
<code>Wash your hands before you eat Yum! Brushy brush! brush!</code>
Il renverra une sortie similaire à ce qui suit:
group('clean_the_house', function(){ task('polish_furniture', function(){..}); task('wash_the_clothes', function(){..}); task('mop_the_floor', function(){..}); });
Passez des paramètres à la tâche
Pour rendre la tâche plus flexible, nous pouvons également transmettre des paramètres. Cela peut être fait en déclarant les paramètres dans la fonction. Cela peut ensuite être utilisé pour accéder aux différents paramètres transmis à la tâche:
phake clean_the_house:polish_furnitureLe paramètre
peut être passé en incluant des paires de valeurs de nom après le nom de la tâche. Si vous souhaitez transmettre plusieurs paramètres, vous pouvez les séparer avec un seul espace entre la valeur du premier paramètre et le nom du deuxième paramètre:
group('clean_the_house', function(){ task('polish_furniture', function(){..}); task('wash_the_clothes', function(){..}); task('mop_the_floor', 'polish_furniture', 'wash_the_clothes', function(){..}); });
Si vous devez passer des paramètres avec des espaces, vous pouvez simplement les enfermer en citations simples ou doubles:
phake clean_the_house:mop_the_floor
Conclusion
Maintenant que nous comprenons à quoi sert Phake et comment l'utiliser pour effectuer des tâches, nous sommes prêts pour certaines des applications pratiques de la deuxième partie. restez à l'écoute!
Des questions fréquemment posées sur l'automatisation du PHP avec Phak
(La partie FAQ est omise ici car elle est trop longue et ne correspond pas à l'objectif pseudo-original. La partie FAQ peut être ajustée et simplifiée au besoin, comme la fusion de certains problèmes, ou seulement les problèmes de base.)
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!

La journalisation PHP est essentielle pour surveiller et déboguer les applications Web, ainsi que pour capturer des événements critiques, des erreurs et un comportement d'exécution. Il fournit des informations précieuses sur les performances du système, aide à identifier les problèmes et prend en charge le dépannage plus rapide

Laravel simplifie la gestion des données de session temporaires à l'aide de ses méthodes de flash intuitives. Ceci est parfait pour afficher de brefs messages, alertes ou notifications dans votre application. Les données ne persistent que pour la demande ultérieure par défaut: $ demande-

L'extension PHP Client URL (CURL) est un outil puissant pour les développeurs, permettant une interaction transparente avec des serveurs distants et des API REST. En tirant parti de Libcurl, une bibliothèque de transfert de fichiers multi-protocol très respectée, PHP Curl facilite Efficient Execu

Laravel fournit une syntaxe de simulation de réponse HTTP concise, simplifiant les tests d'interaction HTTP. Cette approche réduit considérablement la redondance du code tout en rendant votre simulation de test plus intuitive. L'implémentation de base fournit une variété de raccourcis de type de réponse: Utiliser illuminate \ support \ faades \ http; Http :: faux ([[ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

Voulez-vous fournir des solutions instantanées en temps réel aux problèmes les plus pressants de vos clients? Le chat en direct vous permet d'avoir des conversations en temps réel avec les clients et de résoudre leurs problèmes instantanément. Il vous permet de fournir un service plus rapide à votre personnalité

Alipay Php ...

L'article traite de la liaison statique tardive (LSB) dans PHP, introduite dans PHP 5.3, permettant une résolution d'exécution de la méthode statique nécessite un héritage plus flexible. Problème main: LSB vs polymorphisme traditionnel; Applications pratiques de LSB et perfo potentiel

L'article examine l'ajout de fonctionnalités personnalisées aux cadres, en se concentrant sur la compréhension de l'architecture, l'identification des points d'extension et les meilleures pratiques pour l'intégration et le débogage.


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

SublimeText3 version anglaise
Recommandé : version Win, prend en charge les invites de code !

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Version Mac de WebStorm
Outils de développement JavaScript utiles

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

SublimeText3 Linux nouvelle version
Dernière version de SublimeText3 Linux