-
Applications et modèles AppExpert
-
Personnaliser la configuration AppExpert
-
Configurer les services et les groupes de services pour une unité d'application
-
Configurer les 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
-
Configurer l'authentification, l'autorisation et l'audit d'applications
-
-
Configuration de l'expression de stratégie avancée : Mise en route
-
Expressions de stratégie avancées : utilisation de dates, d'heures et de nombres
-
Expressions de stratégie avancées : analyse des données HTTP, TCP et UDP
-
À propos de l'évaluation de la charge utile HTTP et TCP
-
Expressions pour identifier le protocole dans un paquet IP entrant
-
Opérations pour le codage HTTP, HTML et XML et caractères “Safe”
-
Expressions pour évaluer un message DNS et identifier son protocole transporteur
-
-
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
-
Référence aux expressions - Expressions de stratégie avancées
-
Résumé d'exemples d'expressions et de stratégies de syntaxe par défaut
-
Didacticiel exemples de stratégies de syntaxe par défaut pour la réécriture
-
Migration des règles Apache mod_rewrite vers la syntaxe par défaut
-
-
Réécrire des exemples d'action et de stratégie
-
Exemple 1 : supprimer les anciens en-têtes X-Forwarded-For et client-IP
-
Exemple 3 : Marquage des connexions sécurisées et non sécurisées
-
Exemple 6 : Migration des règles du module de réécriture Apache
-
Exemple 8 : rediriger les 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!
A propos de l’évaluation de la charge utile HTTP et TCP
La charge utile d’une requête ou d’une réponse HTTP est constituée d’informations de protocole HTTP telles que des en-têtes, une URL, le contenu du corps et des informations de version et d’état. Lorsque vous configurez une expression de syntaxe par défaut pour évaluer la charge utile HTTP, vous utilisez un préfixe d’expression de syntaxe par défaut et, si nécessaire, un opérateur.
Par exemple, vous utilisez l’expression suivante, qui inclut lehttp.req.header("<header_name>")
préfixe et l’opérateur existant, si vous souhaitez déterminer si une connexion HTTP inclut un en-tête personnalisé nommé « myHeader » :
http.req.header("myHeader").exists
Vous pouvez également combiner plusieurs expressions de stratégie avancées avec des opérateurs booléens et arithmétiques. Par exemple, l’expression composée suivante peut être utile avec diverses fonctionnalités de Citrix ADC, telles que la mise en cache intégrée, la réécriture et le répondeur. Cette expression utilise d’abord l’opérateur && booléen pour déterminer si une connexion HTTP inclut l’en-tête Content-Type avec la valeur “text/html.” Si cette opération renvoie une valeur FALSE, l’expression détermine si la connexion HTTP inclut un en-tête « Transfer-Encoding » ou « Content-Length ».
(http.req.header("Content-Type").exists && http.req.header("Content-Type").eq("text/html")) || (http.req.header("Transfer-Encoding").exists) || (http.req.header("Content-Length").exists)
La charge utile d’un paquet TCP ou UDP est la partie de données du paquet. Vous pouvez configurer des expressions de stratégie avancées pour examiner les fonctionnalités d’un paquet TCP ou UDP, notamment :
- Domaines source et destination
- Ports source et destination
- Le texte dans la charge utile
- Types d’enregistrements
Les préfixes d’expression suivants extraient le texte du corps de la charge utile :
-
HTTP.REQ.BODY(integer)
. Renvoie le corps d’une requête HTTP sous la forme d’un objet texte multiligne, jusqu’à la position du caractère indiquée dans l’argument entier. Si le corps contient moins de caractères que ce qui est spécifié dans l’argument, le corps entier est renvoyé. -
HTTP.RES.BODY(integer)
. Renvoie une partie du corps de réponse HTTP. La longueur du texte retourné est égale au nombre dans l’argument entier. S’il y a moins de caractères dans le corps que ce qui est spécifié dans l’entier, le corps entier est renvoyé. -
CLIENT.TCP.PAYLOAD(integer)
. Retourne les données de charge utile TCP sous forme de chaîne, en commençant par le premier caractère de la charge utile et en continuant le nombre de caractères dans l’argument entier.
Voici un exemple qui évalue à TRUE si un corps de réponse de 1024 octets contient la chaîne « https », et cette chaîne se produit après la chaîne « start string » et avant la chaîne « end string » :
http.res.body(1024).after_str("start_string").before_str("end_string").contains("https")
Remarque : Vous pouvez appliquer n’importe quelle opération de texte au corps de la charge utile. Pour plus d’informations sur les opérations que vous pouvez appliquer au texte, voir Expressions de stratégie avancées : évaluation du texte.
Partager
Partager
Dans cet article
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.