Concepts clés
- Extensibilité de la drusque: Drush, l'interface de ligne de commande de Drupal, permet d'étendre ses fonctionnalités avec des commandes personnalisées définies dans les modules. Cela permet d'automatiser les opérations de Drupal spécifiques.
- Structure de commande: La création d'une commande DRUSH implique un fichier
.drush.inc
(dans votre module), la fonctionhook_drush_command()
pour la définition de commande et une fonction de rappel pour exécuter la logique de la commande. - Arguments et options: Les commandes peuvent accepter les arguments obligatoires et les options facultatives, améliorant la personnalisation. Les arguments sont passés comme paramètres de fonction, tandis que les options sont récupérées à l'aide de
drush_get_option()
. - Entrée interactive et raffinements: Les commandes peuvent demander une entrée utilisateur, fournir des exemples d'utilisation et spécifier les dépendances (niveau de bootstrap Drupal, modules, version de base).
DRUSH rationalise la gestion de Drupal à partir du terminal. Tout en offrant des commandes pré-construites (téléchargement du module, activer, mettre à jour), sa véritable puissance réside dans la création de commandes personnalisées. Ce tutoriel montre la construction d'une commande DRUSH pour un module illustratif simple. L'accent est mis sur la structure de commande de Drush, et non sur la fonctionnalité principale du module. Un exemple de code est disponible dans [ce référentiel] (Repository_link_here - Remplacez par un lien réel si disponible).
Notre module d'échantillon
La fonctionnalité du module demo_drush
est une fonction de base:
function demo_drush_print_statement() { drupal_set_message(t('Hello world!')); }
Cette fonction sera utilisée pour montrer comment Dush imprime les messages à la console. Nous le modifierons plus tard pour présenter diverses fonctionnalités de commande.
Le fichier de commande DRUSH (demo_drush.drush.inc
)
Créer demo_drush.drush.inc
dans le répertoire de votre module. Dush identifie et charge les fonctions à partir de fichiers se terminant par .drush.inc
.
Crochet de commande et rappel
Drush Command Architecture comprend deux parties principales: l'implémentation hook_drush_command()
(définir les commandes et configurations) et les fonctions de rappel déclenchées par des commandes. Commençons par hook_drush_command()
:
/** * Implements hook_drush_command(). */ function drush_demo_drush_command() { $items['drush-demo-command'] = array( 'description' => 'Demonstrates Drush command functionality.', 'aliases' => array('ddc'), ); return $items; }
Ceci définit une commande nommée drush-demo-command
(aliasé comme ddc
). La fonction de rappel (par défaut, drush_drush_demo_command()
) exécute la logique de la commande:
/** * Callback for the drush-demo-command command. */ function drush_drush_demo_command() { demo_drush_print_statement(); }
Après avoir effacé le cache Dush (drush cc drush
), en cours d'exécution drush ddc
imprime "Hello World!" à la console.
Arguments et options
Améliorez votre commande avec des arguments (obligatoires) et des options (facultatifs). Ajoutons-les au crochet:
function demo_drush_print_statement() { drupal_set_message(t('Hello world!')); }
Maintenant, drush ddc error --repeat=10
définit le type d'instruction sur "Error" et le répète 10 fois. Mise à jour demo_drush_print_statement()
et la fonction de rappel en conséquence:
/** * Implements hook_drush_command(). */ function drush_demo_drush_command() { $items['drush-demo-command'] = array( 'description' => 'Demonstrates Drush command functionality.', 'aliases' => array('ddc'), ); return $items; }
Entrée utilisateur
gérer les arguments manquants de manière interactive:
/** * Callback for the drush-demo-command command. */ function drush_drush_demo_command() { demo_drush_print_statement(); }
Exemples dans hook_drush_command()
Ajouter des exemples au crochet:
... 'arguments' => array( 'type' => 'Statement type (error or success).', ), 'options' => array( 'repeat' => 'Number of statement repeats.', ), ...
Conclusion
Ce tutoriel couvre les bases de la création de commandes DRUSH. Explorez des fonctionnalités avancées telles que les niveaux de bootstrap, les dépendances des modules et la compatibilité des versions de base dans la documentation de l'API DRUSH.
Les questions fréquemment posées (FAQ) (elles sont déjà bien écrites dans l'entrée, pas besoin de les réécrire)
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!

Le délai d'expiration de session absolue commence au moment de la création de session, tandis qu'un délai d'expiration inactif de session démarre au moment de la non-opération de l'utilisateur. Le délai d'expiration de session absolue convient aux scénarios où un contrôle strict du cycle de vie de la session est nécessaire, tels que les applications financières; Le délai d'attente de session inactif convient aux applications qui souhaitent que les utilisateurs maintiennent leur session active pendant longtemps, comme les médias sociaux.

La défaillance de la session du serveur peut être résolue en suivant les étapes: 1. Vérifiez la configuration du serveur pour vous assurer que la session est correctement définie. 2. Vérifiez les cookies des clients, confirmez que le navigateur le prend en charge et l'envoyez-le correctement. 3. Vérifiez les services de stockage de session, tels que Redis, pour vous assurer qu'ils fonctionnent normalement. 4. Examiner le code de demande pour assurer la logique de session correcte. Grâce à ces étapes, les problèmes de conversation peuvent être diagnostiqués et réparés efficacement et l'expérience utilisateur peut être améliorée.

Session_Start () IsCrucialInPhpFormanAgingUsersessions.1) ItinitiateSanEwSessionIfNoneExists, 2) ConsomaSanExistingSession, and3) SetSasessionCooKieforContinuityAcrossrequests, permettant aux applications liées à la réaction et à la personne.

La définition de l'indicateur httponly est cruciale pour les cookies de session car il peut effectivement empêcher les attaques XSS et protéger les informations de session utilisateur. Plus précisément, 1) l'indicateur httponly empêche JavaScript d'accéder aux cookies, 2) l'indicateur peut être réglé via Setcookies et Make_Response dans PHP et FLASK, 3) Bien qu'il ne puisse pas être empêché de toutes les attaques, elle devrait faire partie de la politique de sécurité globale.

PhpSessionsSsolvetheproblemOf-MainainingStateCrossMultiplehttprequestsByStoringDataontheserverAndassociatingitwithauniquesessionId.1) ils storentaserver, généralement infilesordatabases, et de lasse de lastoredinacookietatevevedata.2)

PhpSessionsCanstorestrings, Numbers, Arrays, Andobject.1.Strings: TextDatalikeUserames.2.Numbers: IntegersorFloatsForCounters.3.arrays: listslikeshoppingcarts.4.Objects: complexestructuresthataReSerialized.

TostartaphpSession, usessession_start () aTTheScript'sbeginning.1) PlaceItBeForeanyOutputToSetTheSessionCooKie.2) USESSIONSFORUSERDATALIKELOGINSTATUSORSHOPPINGSCARS.3) RegegeraSesessionIdStopreventfixationAtTACKS.4)

La régénération de session fait référence à la génération d'un nouvel ID de session et à l'invalidation de l'ancien ID lorsque l'utilisateur effectue des opérations sensibles en cas d'attaques fixes de session. Les étapes de mise en œuvre incluent: 1. Détectez les opérations sensibles, 2. Générer un nouvel ID de session, 3. Détruiser l'ancien ID de session, 4. Mettre à jour les informations de session côté utilisateur.


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

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

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

Dreamweaver CS6
Outils de développement Web visuel

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

SublimeText3 Linux nouvelle version
Dernière version de SublimeText3 Linux

ZendStudio 13.5.1 Mac
Puissant environnement de développement intégré PHP
