Points de base
- Les crochets GIT sont des scripts exécutés lors de l'exécution de commandes spécifiques, aidant à simplifier les processus de développement et à améliorer l'efficacité. Ces scripts peuvent être utilisés pour effectuer automatiquement des vérifications de style de code pendant le processus de validation afin d'éviter de commettre des erreurs de syntaxe.
- Utilisez Git Hook pour vérifier automatiquement l'orthographe des messages soumis, réduisant les chances d'orthographe et de maintien du professionnalisme. De plus, les crochets peuvent être utilisés pour vérifier automatiquement les erreurs de format afin de garantir que le code répond aux normes adoptées.
- Les crochets GIT peuvent également être utilisés pour effectuer automatiquement des tâches dans des référentiels distants tels que le compositeur pendant le déploiement. Cela simplifie le processus de gestion des dépendances des applications et simplifie le processus de déploiement.
Lors de l'exécution d'une commande spécifique, GIT recherche le répertoire .git/hooks
pour les scripts de crochet appropriés et, s'il est trouvé, les exécute. Vous y trouverez un petit ensemble d'échantillons de scripts (vous pouvez les activer en les renommant pour supprimer le préfixe .sample
et définir leurs bits d'exécution), et vous pouvez trouver une liste complète de crochets dans la page githooks(5)
man. Cet article recommande d'utiliser certains crochets pour simplifier le développement et améliorer l'efficacité.
Vérification du style de code
La soumission de code avec des erreurs de syntaxe n'est pas recommandée. Si les vérifications du style de code peuvent être effectuées automatiquement pendant le processus de validation, cela améliorera considérablement la qualité du code. Si vous exécutez un style de code, vérifiez manuellement avant chaque engagement, l'automatisation empêche l'oublier occasionnel. Le code de shell suivant peut être enregistré comme .git/hooks/pre-commit
(si le code de crochet pre-commit
existe déjà, il peut être annexé) afin que la vérification automatique soit déclenchée sur chaque engagement:
#!/bin/bash git diff --cached --name-status --diff-filter=ACMR | while read STATUS FILE; do if [[ "$FILE" =~ ^.+(php|inc)$ ]]; then php -l "$FILE" 1>/dev/null if [[ $? -ne 0 ]]; then echo "Aborting commit due to files with syntax errors" >&2 exit 1 fi fi done
git diff
Signaler quels modifications se sont produites entre les commits, les options ci-dessus ne renvoient que les fichiers qui ont été ajoutés (a), copiés (C), modifiés (M) ou renommés (R) dans le commit temporaire. Les fichiers avec .php
ou .inc
extensions seront utilisés par la cible pour les vérifications du style de code, et une défaillance du chèque entraînera la sortie du script avec un code de retour non nul, abandonnant l'engagement lui-même.
Soumettre la vérification orthographique du message
La soumission professionnelle est cruciale. Utilisez Git Hook pour vérifier automatiquement l'orthographe des messages soumis pour éviter les erreurs d'orthographe maladroites. Le code suivant peut être enregistré comme .git/hooks/post-commit
(ou appelez); il appelle Aspell et publie une liste de mots suspects. S'il y a une erreur, vous pouvez corriger immédiatement le message de validation en exécutant git commit --amend
.
#!/bin/bash ASPELL=$(which aspell) if [[ $? -ne 0 ]]; then echo "Aspell not installed – unable to check spelling" >&2 exit fi AWK=$(which awk) if [[ $? -ne 0 ]]; then echo "Awk not installed – unable to filter spelling errors" >&2 exit fi # ... (rest of the spell-check code)
Vous pouvez également compiler un dictionnaire supplémentaire (qui peut être déclenché par le crochet post-checkout
) en utilisant l'identifiant extrait du code source du projet et le transmettre à Aspell avec --extra-dicts
pour réduire le nombre de faux positifs.
Vérifier les spécifications du code
Vous pouvez utiliser Git Hook pour vérifier automatiquement que votre code est conforme aux spécifications de code que vous avez adoptées. Le code suivant peut être utilisé comme un post-commit
Hook (.git/hooks/post-commit
) pour vérifier automatiquement les conflits de format.
#!/bin/bash git diff --cached --name-status --diff-filter=ACMR | while read STATUS FILE; do if [[ "$FILE" =~ ^.+(php|inc)$ ]]; then php -l "$FILE" 1>/dev/null if [[ $? -ne 0 ]]; then echo "Aborting commit due to files with syntax errors" >&2 exit 1 fi fi done
Composer de course d'origine
Vous pouvez utiliser Git Hook pour exécuter automatiquement le compositeur pendant le déploiement. Le code suivant peut être placé dans le fichier .git/hooks/post-receive
du référentiel distant pour le crochet post-receive
, qui exécutera automatiquement le compositeur.
#!/bin/bash ASPELL=$(which aspell) if [[ $? -ne 0 ]]; then echo "Aspell not installed – unable to check spelling" >&2 exit fi AWK=$(which awk) if [[ $? -ne 0 ]]; then echo "Awk not installed – unable to filter spelling errors" >&2 exit fi # ... (rest of the spell-check code)
Conclusion
Cet article partage certains crochets GIT qui, espérons-le, simplifient votre processus de développement d'applications et améliore l'efficacité.
Git Hooks FAQ
(La section FAQ est omise ici car l'article est trop long et ne correspond pas à l'objectif pseudo-original. Il peut être conservé ou supprimé au besoin.)
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!

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.

Les séances PHP ont un impact significatif sur les performances des applications. Les méthodes d'optimisation incluent: 1. Utilisez une base de données pour stocker les données de session pour améliorer la vitesse de réponse; 2. Réduire l'utilisation des données de session et stocker uniquement les informations nécessaires; 3. Utilisez un processeur de session non bloquant pour améliorer les capacités de concurrence; 4. Ajustez le temps d'expiration de la session pour équilibrer l'expérience utilisateur et la charge du serveur; 5. Utilisez des séances persistantes pour réduire le nombre de données de lecture et d'écriture.

PhpsessionsareServer-côté, whileCookiesareclient-Side.1) SessionStoredataontheServer, aremoresecure, ethandleLargerData.2) CookiesstoredataontheClient, ArelessSecure, andlimitedIzeSize.USESESSIONSFORSENSEDATAANDCOOKIESFORNONNORNE-SENSENSITION, Client-Sidedata.

Phpidentifiesauser'sessionusingssse cookiesand sessionids.1) whenSession_start () est calculé, phpgeneratesauquesseSessionIdStoredInacookIenameDPhpSesssIdonUser'sbrowser.2) thisIdallowsphptoreTrrieSeSessionDatafromTeserver.

La sécurité des sessions PHP peut être obtenue grâce aux mesures suivantes: 1. Utilisez Session_RegeReate_ID () pour régénérer l'ID de session lorsque l'utilisateur se connecte ou est une opération importante. 2. Cryptez l'ID de session de transmission via le protocole HTTPS. 3. Utilisez session_save_path () pour spécifier le répertoire sécurisé pour stocker les données de session et définir correctement les autorisations.

PhpSessionFilesArestorentheDirectorySpecifiedSession.save_path, généralement / tmponunix-likesystemsorc: \ windows \ temponwindows.tocustomzethis: 1) usession_save_path () tosetacustomDirectory, astumeit'swrit


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

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

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

Listes Sec
SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

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

Dreamweaver Mac
Outils de développement Web visuel
