-
-
Personnaliser la configuration d'AppExpert
-
Configuration des services et des groupes de services pour une unité d'application
-
Configurer des points de terminaison publics pour une application
-
Configurer des groupes de persistance pour les unités d'application
-
Afficher les applications AppExpert et configurer les entités à l'aide du visualiseur d'applications
-
Configuration de l'authentification, de l'autorisation et de l'audit des applications
-
-
Configuration de l'expression de stratégie avancée : mise en route
-
Expressions de stratégie avancées : utilisation des dates, des heures et des nombres
-
Expressions de stratégie avancées : analyse des données HTTP, TCP et UDP
-
Expressions de stratégie avancées : analyse des certificats SSL
-
Expressions de stratégie avancées : adresses IP et MAC, débit, ID VLAN
-
Expressions de stratégie avancées : fonctions d'analyse de flux
-
-
Comportement de l'en-tête Content-length dans une stratégie de réécriture
-
Exemples d'actions et de stratégies de réécriture
-
Exemple 1 : Supprimer les anciens en-têtes X-Forwarded-For et Client-IP
-
Exemple 3 : Balisage des connexions sécurisées et non sécurisées
-
Exemple 6 : migration des règles du module de réécriture Apache
-
Exemple 8 : Redirection des requêtes vers le serveur interrogé
-
Exemple 11 : chiffrement RSA basé sur une stratégie sans remplissage
-
-
This content has been machine translated dynamically.
Dieser Inhalt ist eine maschinelle Übersetzung, die dynamisch erstellt wurde. (Haftungsausschluss)
Cet article a été traduit automatiquement de manière dynamique. (Clause de non responsabilité)
Este artículo lo ha traducido una máquina de forma dinámica. (Aviso legal)
此内容已经过机器动态翻译。 放弃
このコンテンツは動的に機械翻訳されています。免責事項
이 콘텐츠는 동적으로 기계 번역되었습니다. 책임 부인
Este texto foi traduzido automaticamente. (Aviso legal)
Questo contenuto è stato tradotto dinamicamente con traduzione automatica.(Esclusione di responsabilità))
This article has been machine translated.
Dieser Artikel wurde maschinell übersetzt. (Haftungsausschluss)
Ce article a été traduit automatiquement. (Clause de non responsabilité)
Este artículo ha sido traducido automáticamente. (Aviso legal)
この記事は機械翻訳されています.免責事項
이 기사는 기계 번역되었습니다.책임 부인
Este artigo foi traduzido automaticamente.(Aviso legal)
这篇文章已经过机器翻译.放弃
Questo articolo è stato tradotto automaticamente.(Esclusione di responsabilità))
Translation failed!
Opérations de base sur le texte
Les opérations de base sur le texte incluent les opérations de correspondance de chaînes, de calcul de la longueur d’une chaîne et de contrôle de la sensibilité à la casse. Vous pouvez inclure des espaces blancs dans une chaîne passée en tant qu’argument à une expression, mais la chaîne ne peut pas dépasser 255 caractères.
Fonctions de comparaison de chaînes
Le tableau suivant répertorie les opérations de correspondance de chaînes de base dans lesquelles les fonctions renvoient une valeur booléenne TRUE ou FALSE.
Fonction | Description |
---|---|
<text>.CONTAINS(<string>) |
Renvoie une valeur booléenne TRUE si la cible contient <string> . Exemple : http.req.url.contains(".jpeg")
|
<text>.EQ(<string>) |
Renvoie une valeur booléenne TRUE si la cible correspond exactement à <string> . Par exemple, l’expression suivante renvoie une valeur booléenne TRUE pour une URL dont le nom d’hôte est « myhostabc » : http.req.url.hostname.eq("myhostabc")
|
<text>.STARTSWITH(<string>) |
Renvoie une valeur booléenne TRUE si la cible commence par <string> . Par exemple, l’expression suivante renvoie une valeur booléenne TRUE pour une URL dont le nom d’hôte est « myhostabc » : http.req.url.hostname.startswith("myhost")
|
<text>.ENDSWITH(<string>) |
Renvoie une valeur booléenne TRUE si la cible se termine par http.req.url.hostname.endswith("abc") |
<text>.NE(<string>) |
Renvoie une valeur booléenne TRUE si le préfixe n’est pas égal à l’argument de chaîne. Si le préfixe renvoie une valeur qui n’est pas une chaîne, l’argument de la fonction est comparé à la représentation sous forme de chaîne de la valeur renvoyée par le préfixe. Vous pouvez utiliser les fonctions avec SET_TEXT_MODE(IGNORECASE) or SET_TEXT_MODE(NOIGNORECASE) et avec les jeux de caractères ASCII et UTF-8. |
<text>.GT(<string>) |
Renvoie une valeur booléenne TRUE si le préfixe est alphabétiquement supérieur à l’argument de chaîne. Si le préfixe renvoie une valeur qui n’est pas une chaîne, l’argument de la fonction est comparé à la représentation sous forme de chaîne de la valeur renvoyée par le préfixe. Vous pouvez utiliser les fonctions avec SET_TEXT_MODE(IGNORECASE) ou SET_TEXT_MODE(NOIGNORECASE) , et avec les jeux de caractères ASCII et UTF-8. |
<text>.GE(<string> ) |
Renvoie une valeur booléenne TRUE si le préfixe est alphabétiquement supérieur ou égal à l’argument de chaîne. Si le préfixe renvoie une valeur qui n’est pas une chaîne, l’argument de la fonction est comparé à la représentation sous forme de chaîne de la valeur renvoyée par le préfixe. Vous pouvez utiliser les fonctions avec SET_TEXT_MODE(IGNORECASE) ou SET_TEXT_MODE(NOIGNORECASE) , et avec les jeux de caractères ASCII et UTF-8. |
<text>.LT(<string> ) |
Renvoie une valeur booléenne TRUE si le préfixe est alphabétiquement inférieur à l’argument chaîne. Si le préfixe renvoie une valeur qui n’est pas une chaîne, l’argument de la fonction est comparé à la représentation sous forme de chaîne de la valeur renvoyée par le préfixe. Vous pouvez utiliser les fonctions avec SET_TEXT_MODE(IGNORECASE) ou SET_TEXT_MODE(NOIGNORECASE) , et avec les jeux de caractères ASCII et UTF-8. |
<text>.LE(<string>) |
Renvoie une valeur booléenne TRUE si le préfixe est alphabétiquement inférieur ou égal à l’argument chaîne. Si le préfixe renvoie une valeur qui n’est pas une chaîne, l’argument de la fonction est comparé à la représentation sous forme de chaîne de la valeur renvoyée par le préfixe. Vous pouvez utiliser les fonctions avec SET_TEXT_MODE(IGNORECASE) ou SET_TEXT_MODE(NOIGNORECASE) , et avec les jeux de caractères ASCII et UTF-8. |
Calculer la longueur d’une chaîne
L’ <text>.LENGTH
opération renvoie une valeur numérique égale au nombre de caractères (et non d’octets) d’une chaîne :
<text>.LENGTH
Par exemple, vous pouvez souhaiter identifier les URL de demande qui dépassent une longueur particulière. Voici une expression qui implémente cet exemple :
HTTP.REQ.URL.LENGTH < 500
Après avoir compté les caractères ou les éléments d’une chaîne, vous pouvez leur appliquer des opérations numériques. Pour plus d’informations, consultez Expressions de stratégie avancées : utilisation des dates, des heures et des nombres.
Considérez, ignorez et modifiez la casse du texte
Les fonctions suivantes fonctionnent sur la casse (majuscule ou minuscule) des caractères de la chaîne.
|Fonction|Description|
|— |— |
|<text>.SET_TEXT_MODE
(IGNORECASE| NOIGNORECASE)|Cette fonction active ou désactive la sensibilité à la casse pour toutes les opérations de texte. |
|<text>.TO_LOWER
|Convertit la cible en minuscules pour un bloc de texte d’une taille maximale de 2 kilo-octets (Ko). Renvoie UNDEF si la cible dépasse 2 Ko. Par exemple, la chaîne « abCD : » est convertie en « abcd : » .|
|<text>.TO_UPPER
|Convertit la cible en majuscules. Renvoie UNDEF si la cible dépasse 2 Ko. Par exemple, la chaîne « AbCD : » est convertie en « ABCD : » .|
Dépouille des caractères spécifiques d’une chaîne
Vous pouvez utiliser la fonction STRIP_CHARS (<string>
) pour supprimer des caractères spécifiques du texte renvoyé par un préfixe d’expression de stratégie avancée (la chaîne d’entrée). Toutes les instances des caractères spécifiés dans l’argument sont retirées de la chaîne d’entrée. Vous pouvez utiliser n’importe quelle méthode de texte sur la chaîne résultante, y compris les méthodes utilisées pour faire correspondre la chaîne à un jeu de motifs.
Par exemple, dans l’expression CLIENT.UDP.DNS.DOMAIN.STRIP\_CHARS(".-\_")
, la fonction STRIP\_CHARS(<string>)
supprime tous les points (.), tirets (-) et traits de soulignement (_) du nom de domaine renvoyé par le préfixe CLIENT.UDP.DNS.DOMAIN. Si le nom de domaine renvoyé est « a.dom_ai_n-name », la fonction renvoie la chaîne « adomainname ».
Dans l’exemple suivant, la chaîne résultante est comparée à un jeu de motifs appelé « listofdomains » :
CLIENT.UDP.DNS.DOMAIN.STRIP_CHARS(".-_").CONTAINS_ANY("listofdomains")
Remarque : Vous ne pouvez pas effectuer de réécriture sur la chaîne renvoyée par la fonction STRIP_CHARS(<string>)
.
Les fonctions suivantes enlève les caractères correspondants du début et de la fin d’une entrée de chaîne donnée.
Fonction | Description |
---|---|
<text>.STRIP_START_CHARS(s) |
Enlève les caractères correspondants depuis le début de la chaîne d’entrée jusqu’à ce que le premier caractère non concordant soit trouvé et renvoie le reste de la chaîne. Vous devez spécifier les caractères que vous souhaitez supprimer sous la forme d’une chaîne unique entre guillemets. Par exemple, si le nom d’un en-tête est TestLang et que :/en_us:est sa valeur, HTTP.RES.HEADER (« TestLang ») .STRIP_START_CHARS (« : «) supprime les caractères spécifiés depuis le début de la valeur de l’en-tête jusqu’à ce que le premier caractère non correspondant e soit trouvé et renvoie sen_us : sous la forme d’un chaîne. |
<text >.STRIP_END_CHARS(s) |
Enlève les caractères correspondants depuis la fin de la chaîne d’entrée jusqu’au premier caractère non correspondant est trouvé et renvoie le reste de la chaîne. Vous devez spécifier les caractères que vous souhaitez supprimer sous la forme d’une chaîne unique entre guillemets. Par exemple, si le nom d’un en-tête est TestLang et que :/en_us:is its value,HTTP.RES.HEADER(“TestLang”).STRIP_START_CHARS(“:”) supprime les caractères spécifiés à partir de la fin de la valeur de l’en-tête jusqu’à ce que le premier caractère non correspondant s soit trouvé et renvoie : /_en_us sous forme de chaîne. |
Ajouter une chaîne à une autre chaîne
Vous pouvez utiliser la fonction APPEND () pour ajouter la représentation sous forme de chaîne de l’argument à la représentation sous forme de chaîne de la valeur renvoyée par la fonction précédente. La fonction précédente peut être une fonction qui renvoie un nombre, un long non signé, un double, une valeur temporelle, une adresse IPv4 ou une adresse IPv6. L’argument peut être une chaîne de texte, un nombre, un long non signé, un double, une valeur temporelle, une adresse IPv4 ou une adresse IPv6. La valeur de chaîne résultante est la même valeur de chaîne que celle obtenue à l’aide de l’opérateur +.
Partager
Partager
This Preview product documentation is Cloud Software Group Confidential.
You agree to hold this documentation confidential pursuant to the terms of your Cloud Software Group Beta/Tech Preview Agreement.
The development, release and timing of any features or functionality described in the Preview documentation remains at our sole discretion and are subject to change without notice or consultation.
The documentation is for informational purposes only and is not a commitment, promise or legal obligation to deliver any material, code or functionality and should not be relied upon in making Cloud Software Group product purchase decisions.
If you do not agree, select I DO NOT AGREE to exit.