


Résumé des expressions régulières PHP et des annotations grammaticales couramment utilisées
Syntaxe de base
Délimiteur :
identifie le début et la fin d'une expression régulière, utilisez '/' ou ' #' ou '{ }', car la syntaxe '{ }' peut également être un opérateur d'expression régulière, pour éviter toute confusion, il n'est pas recommandé de l'utiliser. L'utilisation recommandée est la suivante :
Copy$pattern = '/[0-9]/'; //我喜欢这个,看起来比较简洁 $pattern = '#[0-9]#';
Atomes :
Atomes visibles : caractères de la table d'encodage Unicode visibles à l'œil nu après une sortie au clavier, par exemple : Ponctuation ; / Ou des caractères visibles tels que des lettres anglaises, des caractères chinois, etc.
Atomes invisibles : caractères de la table de codage Unicode qui sont invisibles à l'œil nu après une sortie au clavier, tels que : nouvelle ligne n, Tab t, espace, etc. ,
Généralement, seuls ces trois caractères sont utilisés (les caractères de nouvelle ligne sont généralement mis en correspondance avec d'autres caractères, car seuls les caractères de nouvelle ligne ne peuvent pas correspondre)
Conseils : vous devez ajouter ' ' avant l'opérateur de correspondance. Par exemple : signe '+', en cas de correspondance, vous devez écrire '+'
métacaractères
Méthode de filtrage atomique :
| Faire correspondre deux ou plusieurs sélections de branches
[] correspond à n'importe quel atome entre crochets
[^] correspond à n'importe quel caractère à l'exception des atomes entre crochets
Exemple : Duang| duang ou [Dd]uang Les deux peuvent correspondre à Duang et duang
écriture à intervalles : [a-z] correspond aux caractères de a à z, [0-9] correspond aux caractères de 0 à 9. Il peut également s'agir de [a-z0-9]
Correspond à n'importe quel caractère, à l'exception du caractère de nouvelle ligne
d correspond à n'importe quel chiffre décimal, c'est-à-dire que {0-9]
D correspond à n'importe quel chiffre non décimal [^. 0-9] équivaut à [^d]
s correspondant à un atome invisible, c'est-à-dire [fnrtv]
S correspond à un atome visible, c'est-à-dire [fnrtv], équivalent à [s]z
w Correspond à n'importe quel chiffre, lettre ou trait de soulignement, c'est-à-dire [0-9a-zA-Z_]
W correspond à n'importe quel autre chiffre, lettre ou trait de soulignement, [0-9a-zA-Z_], ce qui équivaut à [w]
Quantificateur
{n} signifie que l'atome devant lui apparaît exactement n fois.
[n] signifie que l'atome précédent apparaît au moins n fois
{n,m} apparaît au moins n fois et au plus m fois
* correspond à 0 fois, une ou plusieurs fois, c'est-à-dire, {0,}
+ correspond à une ou plusieurs fois, c'est-à-dire {1,}
? Correspond à 0 ou 1 fois, c'est-à-dire {0,1}
Contrôle des frontières
^ correspond à la position de départ de la chaîne
$ correspond à la position de fin de la chaîne
Exemple : ^John peut correspondre à : John mais ne peut pas correspondre à : 123John, car la chaîne est spécifié pour commencer par John Commençant par
unité de modèle
() correspond à la partie entière en tant qu'atome, tel que : (X|x)iaomi , qui peut correspondre à xiaomi
Mode de correction
Correspondance gourmande
Lorsque le résultat de la correspondance est ambigu, prenez le plus long (par défaut)
Correspondance paresseuse
Lorsque le résultat de la correspondance est ambigu, choisissez le plus court, ajoutez simplement 'U' après '/' dans l'expression régulière, pour exemple '/[0-9]/U';
Exemple :
Copy$subject = "test__123123123"; preg_match('/test.+123/', $subject, $matches); //贪婪模式 var_dump($matches); preg_match('/test.+123/U', $subject, $matches); //懒惰模式var_dump($matches);
Modèles de correction courants :
U Correspondance paresseuse
i Ignorer la casse des lettres anglaises
x Ignorer les caractères d'espacement dans les expressions régulières
s Laisser le métacaractère '.' correspondre à tous les caractères, y compris les nouvelles lignes
Fonctions communes
preg_match
sont exécutés Match Regular Expression
preg_match ( string $pattern , string $subject [, array &$matches [, int $flags = 0 [, int $offset = 0 ]]] ) : int
pattern : modèle à rechercher, type de chaîne. sujet : chaîne d'entrée. match : si le paramètre matches est fourni, il sera rempli avec les résultats de la recherche et la structure des données est un tableau unidimensionnel. flags : peut être défini sur PREG_OFFSET_CAPTURE, en utilisant le 0ème élément du résultat de la recherche comme chaîne correspondante et le 1er élément comme décalage (position) correspondant. offset : La recherche commence à partir de la position de départ de la chaîne cible.
Valeur de retour : nombre de correspondances
Similaire à la fonction preg_match_all, les paramètres sont cohérents avec preg_match
Différence :
preg_match : ne correspond qu'une seule fois, le résultat des données de la recherche la structure de correspondance est un tableau unidimensionnel preg_match_all : Correspond à tout, la structure de données de la correspondance des résultats de recherche est un tableau à deux dimensions.
preg_replace
Effectue une recherche et un remplacement d'expression régulière, et la valeur de retour est la chaîne remplacée
preg_replace ( mixed $pattern , mixed $replacement , mixed $subject [, int $limit = -1 [, int &$count ]] ) : mixed
pattern : le modèle à rechercher. Peut être une chaîne ou un tableau de chaînes. remplacement : une chaîne ou un tableau de chaînes utilisé pour le remplacement. sujet : une chaîne ou un tableau de chaînes à rechercher et à remplacer. limite : le nombre maximum de remplacements. La valeur par défaut est -1 (illimité). count : nombre de remplacements.
Similaire à la fonction preg_filter, les paramètres sont les mêmes que preg_replace
Différences (la différence ne peut être vue qu'en utilisant des tableaux pour la correspondance) : preg_replace : renvoie tous les résultats, qu'il y ait remplacement ou non. preg_filter : uniquement renvoie des résultats correspondants.
preg_split
Séparer les chaînes par une expression régulière
preg_split ( string $pattern , string $subject [, int $limit = -1 [, int $flags = 0 ]] ) : array
$pattrn:用于搜索的模式,字符串形式。subject:输入字符串limit:将限制分隔得到的子串最多只有limit个,返回的最后一个 子串将包含所有剩余部分。flags:有以下标记的组合:
-- 1. PREG_SPLIT_NO_EMPTY: 返回分隔后的非空部分。
-- 2. PREG_SPLIT_DELIM_CAPTURE: 用分隔符'()'括号把匹配的捕获并返回。
-- 3. PREG_SPLIT_OFFSET_CAPTURE: 匹配返回时将会附加字符串偏移量
PREG_SPLIT_DELIM_CAPTURE这个参数可能比较难明白,举个例子看看:
Copy$subject = "1a23b"; $a = preg_split('/[\d]/', $subject, -1, PREG_SPLIT_NO_EMPTY); var_dump($a); $a = preg_split('/([\d])/', $subject, -1, PREG_SPLIT_NO_EMPTY | PREG_SPLIT_DELIM_CAPTURE); var_dump($a);
输出如下:
array (size=2)
0 => string 'a' (length=1)
1 => string 'b' (length=1)
array (size=5)
0 => string '1' (length=1)
1 => string 'a' (length=1)
2 => string '2' (length=1)
3 => string '3' (length=1)
4 => string 'b' (length=1)
preg_grep
返回匹配模式的数组条目
preg_grep ( string $pattern , array $input [, int $flags = 0 ] ) : array
$pattern:要搜索的模式,字符串形式$input:输入数组flags:如果不设置则返回匹配的数目,设置PREG_GREP_INVERT则返回不匹配的数目。
preg_quote
转义正则表达式字符,返回为转义后的字符串
preg_quote ( string $str [, string $delimiter = NULL ] ) : string
str:输入字符串delimiter:需要转义的字符串
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!

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

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

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

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Alipay Php ...

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

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 traite des fonctionnalités de sécurité essentielles dans les cadres pour se protéger contre les vulnérabilités, notamment la validation des entrées, l'authentification et les mises à jour régulières.

Envoyant des données JSON à l'aide de la bibliothèque Curl de PHP dans le développement de PHP, il est souvent nécessaire d'interagir avec les API externes. L'une des façons courantes consiste à utiliser la bibliothèque Curl pour envoyer le post� ...

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.

L'application du principe solide dans le développement de PHP comprend: 1. Principe de responsabilité unique (SRP): Chaque classe n'est responsable d'une seule fonction. 2. Principe ouvert et ferme (OCP): les changements sont réalisés par extension plutôt que par modification. 3. Principe de substitution de Lisch (LSP): les sous-classes peuvent remplacer les classes de base sans affecter la précision du programme. 4. Principe d'isolement d'interface (ISP): utilisez des interfaces à grain fin pour éviter les dépendances et les méthodes inutilisées. 5. Principe d'inversion de dépendance (DIP): les modules élevés et de bas niveau reposent sur l'abstraction et sont mis en œuvre par injection de dépendance.

Le détournement de la session peut être réalisé via les étapes suivantes: 1. Obtenez l'ID de session, 2. Utilisez l'ID de session, 3. Gardez la session active. Les méthodes pour empêcher le détournement de la session en PHP incluent: 1. Utilisez la fonction Session_RegeReate_id () pour régénérer l'ID de session, 2. Stocker les données de session via la base de données, 3. Assurez-vous que toutes les données de session sont transmises via HTTPS.
