]> granicus.if.org Git - apache/blob - docs/manual/filter.html.fr
xforms
[apache] / docs / manual / filter.html.fr
1 <?xml version="1.0" encoding="ISO-8859-1"?>
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml" lang="fr" xml:lang="fr"><head><!--
4         XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
5               This file is generated from xml source: DO NOT EDIT
6         XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
7       -->
8 <title>Filtres - Serveur Apache HTTP</title>
9 <link href="./style/css/manual.css" rel="stylesheet" media="all" type="text/css" title="Main stylesheet" />
10 <link href="./style/css/manual-loose-100pc.css" rel="alternate stylesheet" media="all" type="text/css" title="No Sidebar - Default font size" />
11 <link href="./style/css/manual-print.css" rel="stylesheet" media="print" type="text/css" /><link rel="stylesheet" type="text/css" href="./style/css/prettify.css" />
12 <script src="./style/scripts/prettify.js" type="text/javascript">
13 </script>
14
15 <link href="./images/favicon.ico" rel="shortcut icon" /></head>
16 <body id="manual-page"><div id="page-header">
17 <p class="menu"><a href="./mod/">Modules</a> | <a href="./mod/directives.html">Directives</a> | <a href="./faq/">FAQ</a> | <a href="./glossary.html">Glossaire</a> | <a href="./sitemap.html">Plan du site</a></p>
18 <p class="apache">Serveur Apache HTTP Version 2.5</p>
19 <img alt="" src="./images/feather.gif" /></div>
20 <div class="up"><a href="./"><img title="&lt;-" alt="&lt;-" src="./images/left.gif" /></a></div>
21 <div id="path">
22 <a href="http://www.apache.org/">Apache</a> &gt; <a href="http://httpd.apache.org/">Serveur HTTP</a> &gt; <a href="http://httpd.apache.org/docs/">Documentation</a> &gt; <a href="./">Version 2.5</a></div><div id="page-content"><div id="preamble"><h1>Filtres</h1>
23 <div class="toplang">
24 <p><span>Langues Disponibles: </span><a href="./en/filter.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
25 <a href="./es/filter.html" hreflang="es" rel="alternate" title="Español">&nbsp;es&nbsp;</a> |
26 <a href="./fr/filter.html" title="Français">&nbsp;fr&nbsp;</a> |
27 <a href="./ja/filter.html" hreflang="ja" rel="alternate" title="Japanese">&nbsp;ja&nbsp;</a> |
28 <a href="./ko/filter.html" hreflang="ko" rel="alternate" title="Korean">&nbsp;ko&nbsp;</a> |
29 <a href="./tr/filter.html" hreflang="tr" rel="alternate" title="Türkçe">&nbsp;tr&nbsp;</a></p>
30 </div>
31
32     <p>Ce document décrit l'utilisation des filtres avec Apache.</p>
33   </div>
34 <div id="quickview"><ul id="toc"><li><img alt="" src="./images/down.gif" /> <a href="#intro">Le filtrage avec Apache 2</a></li>
35 <li><img alt="" src="./images/down.gif" /> <a href="#smart">Filtrage intelligent</a></li>
36 <li><img alt="" src="./images/down.gif" /> <a href="#service">Présentation des filtres en tant que service HTTP</a></li>
37 <li><img alt="" src="./images/down.gif" /> <a href="#using">Utilisation des filtres</a></li>
38 </ul></div>
39 <div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
40 <div class="section">
41 <h2><a name="intro" id="intro">Le filtrage avec Apache 2</a></h2>
42     
43     <table class="related"><tr><th>Modules Apparentés</th><th>Directives Apparentées</th></tr><tr><td><ul><li><code class="module"><a href="./mod/mod_filter.html">mod_filter</a></code></li><li><code class="module"><a href="./mod/mod_deflate.html">mod_deflate</a></code></li><li><code class="module"><a href="./mod/mod_ext_filter.html">mod_ext_filter</a></code></li><li><code class="module"><a href="./mod/mod_include.html">mod_include</a></code></li><li><code class="module"><a href="./mod/mod_charset_lite.html">mod_charset_lite</a></code></li><li><code class="module"><a href="./mod/mod_reflector.html">mod_reflector</a></code></li><li><code class="module"><a href="./mod/mod_buffer.html">mod_buffer</a></code></li><li><code class="module"><a href="./mod/mod_data.html">mod_data</a></code></li><li><code class="module"><a href="./mod/mod_ratelimit.html">mod_ratelimit</a></code></li><li><code class="module"><a href="./mod/mod_reqtimeout.html">mod_reqtimeout</a></code></li><li><code class="module"><a href="./mod/mod_request.html">mod_request</a></code></li><li><code class="module"><a href="./mod/mod_sed.html">mod_sed</a></code></li><li><code class="module"><a href="./mod/mod_substitute.html">mod_substitute</a></code></li><li><code class="module"><a href="./mod/mod_xml2enc.html">mod_xml2enc</a></code></li><li><code class="module"><a href="./mod/mod_proxy_html.html">mod_proxy_html</a></code></li><li><code class="module"><a href="./mod/mod_policy.html">mod_policy</a></code></li></ul></td><td><ul><li><code class="directive"><a href="./mod/mod_filter.html#filterchain">FilterChain</a></code></li><li><code class="directive"><a href="./mod/mod_filter.html#filterdeclare">FilterDeclare</a></code></li><li><code class="directive"><a href="./mod/mod_filter.html#filterprotocol">FilterProtocol</a></code></li><li><code class="directive"><a href="./mod/mod_filter.html#filterprovider">FilterProvider</a></code></li><li><code class="directive"><a href="./mod/mod_mime.html#addinputfilter">AddInputFilter</a></code></li><li><code class="directive"><a href="./mod/mod_mime.html#addoutputfilter">AddOutputFilter</a></code></li><li><code class="directive"><a href="./mod/mod_mime.html#removeinputfilter">RemoveInputFilter</a></code></li><li><code class="directive"><a href="./mod/mod_mime.html#removeoutputfilter">RemoveOutputFilter</a></code></li><li><code class="directive"><a href="./mod/mod_reflector.html#reflectorheader">ReflectorHeader</a></code></li><li><code class="directive"><a href="./mod/mod_ext_filter.html#extfilterdefine">ExtFilterDefine</a></code></li><li><code class="directive"><a href="./mod/mod_ext_filter.html#extfilteroptions">ExtFilterOptions</a></code></li><li><code class="directive"><a href="./mod/core.html#setinputfilter">SetInputFilter</a></code></li><li><code class="directive"><a href="./mod/core.html#setoutputfilter">SetOutputFilter</a></code></li></ul></td></tr></table>
44
45 <p>La chaîne de filtrage est disponible depuis la version 2.0 d'Apache,
46 et permet aux applications de traiter les données en entrée et en sortie
47 d'une manière hautement flexible et configurable, quelle que soit la
48 provenance de ces données.  Il est possible de pré-traiter les données
49 en entrée, et post-traiter les données en sortie, comme souhaité.
50 Ces traitements sont tout à fait indépendants des traditionnelles phases
51 de traitement des requêtes.</p>
52 <p class="figure">
53 <img src="images/filter_arch.png" width="569" height="392" alt="les filtres peuvent s'enchaîner, perpendiculairement au traitement des requêtes" />
54 </p>
55 <p>Voici quelques exemples de filtrage avec la distribution standard d'Apache:</p>
56 <ul>
57 <li><code class="module"><a href="./mod/mod_include.html">mod_include</a></code>, implémente les inclusions côté serveur.</li>
58 <li><code class="module"><a href="./mod/mod_ssl.html">mod_ssl</a></code>, implémente le cryptage SSL (https).</li>
59 <li><code class="module"><a href="./mod/mod_deflate.html">mod_deflate</a></code>, implémente la compression/décompression
60 à la volée.</li>
61 <li><code class="module"><a href="./mod/mod_charset_lite.html">mod_charset_lite</a></code>, transcodage entre différents
62 jeux de caractères.</li>
63 <li><code class="module"><a href="./mod/mod_ext_filter.html">mod_ext_filter</a></code>, utilisation d'un programme externe
64 comme filtre.</li>
65 </ul>
66 <p>Apache utilise aussi plusieurs filtres en interne pour accomplir des tâches
67 comme le découpage des grosses requêtes (chunking) et la gestion des
68 requêtes portant sur une partie d'un fichier (byte-range).</p>
69
70 <p>Un grand choix d'applications sont implémentées par des modules de filtrage
71 tiers disponibles à <a href="http://modules.apache.org/">modules.apache.org</a> entre autres.
72 En voici quelques exemples :</p>
73
74 <ul>
75 <li>Traitement et réécriture HTML et XML</li>
76 <li>Transformations XSLT et inclusions XML (XIncludes)</li>
77 <li>Support de l'espace de nommage XML</li>
78 <li>Gestion du chargement de fichier et décodage des formulaires HTML</li>
79 <li>Traitement d'image</li>
80 <li>Protection des applications vulnérables comme les scripts PHP</li>
81 <li>Edition de texte par Chercher/Remplacer</li>
82 </ul>
83 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
84 <div class="section">
85 <h2><a name="smart" id="smart">Filtrage intelligent</a></h2>
86
87 <p class="figure">
88 <img src="images/mod_filter_new.png" width="423" height="331" alt="Le filtrage intelligent applique différents fournisseurs de filtrage en fonction de l'état du traitement de la requête" />
89 </p>
90 <p><code class="module"><a href="./mod/mod_filter.html">mod_filter</a></code>, inclus dans les version 2.1 et supérieures
91 d'Apache, permet de configurer la chaîne de filtrage dynamiquement
92 à l'exécution.
93 Ainsi par exemple, vous pouvez définir un proxy pour réécrire du code HTML
94 avec un filtre HTML et traiter des images JPEG avec un filtre totalement
95 séparé, bien que le proxy ne possède aucune information préliminaire
96 sur ce que le serveur à l'origine des données à filtrer va envoyer.
97 Ceci fonctionne grâce à l'utilisation d'un gestionnaire de filtre,
98 qui distribue les tâches à différents fournisseurs de filtrage en fonction
99 du contenu réel à filtrer à l'exécution.  Tout filtre peut se voir soit
100 inséré directement dans la chaîne et lancé inconditionnellement, soit
101 utilisé comme un fournisseur de filtrage et inséré dynamiquement.
102 Par exemple,</p>
103 <ul>
104 <li>un filtre de traitement HTML sera lancé uniquement si le contenu est
105 de type text/html ou application/xhtml+xml</li>
106 <li>Un filtre de compression sera lancé uniquement si les données en entrée
107 sont de type compressible et non déjà compressées</li>
108 <li>Un filtre de conversion de jeux de caractères ne sera inséré que si
109 le document texte n'est pas déjà dans le jeu de caractères voulu</li>
110 </ul>
111 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
112 <div class="section">
113 <h2><a name="service" id="service">Présentation des filtres en tant que service HTTP</a></h2>
114
115
116 <p>Les filtres permettent de traiter les contenus en provenance du
117 serveur. Le module <code class="module"><a href="./mod/mod_reflector.html">mod_reflector</a></code> permet aussi
118 d'utiliser les filtres pour traiter les contenus en provenance du
119 client.</p>
120
121 <p>Le module <code class="module"><a href="./mod/mod_reflector.html">mod_reflector</a></code> reçoit les requêtes POST des
122 clients, et en répercute le corps dans la requête POST constituant la
123 réponse, lors de l'envoi de cette dernière au client en passant à travers la
124 pile de filtres en sortie.</p>
125
126 <p>Cette technique peut être utilisée comme alternative à un service web
127 s'exécutant à l'intérieur de la pile d'un serveur d'applications, où un
128 filtre en sortie effectue la transformation requise sur le corps de la
129 requête. Par exemple, on peut utiliser le module
130 <code class="module"><a href="./mod/mod_deflate.html">mod_deflate</a></code> pour fournir un service général de
131 compression ; un filtre de transformation d'images peut aussi se voir
132 mué en service de transformation d'images.</p>
133
134 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
135 <div class="section">
136 <h2><a name="using" id="using">Utilisation des filtres</a></h2>
137
138 <p>Il y a deux manières d'utiliser le filtrage : Simple et Dynamique.
139 En général, vous utiliserez l'une ou l'autre méthode; le mélange des deux
140 peut avoir des conséquences inattendues (bien que le filtrage simple en entrée
141 puisse être associé sans problème avec le filtrage simple ou dynamique
142 en sortie).</p>
143 <p>La méthode Simple est la seule permettant de configurer les filtres
144 en entrée, et suffit pour les filtres en sortie pour lesquels vous avez besoin
145 d'une chaîne de filtres statique.
146 Les directives correspondantes sont
147     <code class="directive"><a href="./mod/core.html#setinputfilter">SetInputFilter</a></code>,
148     <code class="directive"><a href="./mod/core.html#setoutputfilter">SetOutputFilter</a></code>,
149     <code class="directive"><a href="./mod/mod_mime.html#addinputfilter">AddInputFilter</a></code>,
150     <code class="directive"><a href="./mod/mod_mime.html#addoutputfilter">AddOutputFilter</a></code>,
151     <code class="directive"><a href="./mod/mod_mime.html#removeinputfilter">RemoveInputFilter</a></code>, et
152     <code class="directive"><a href="./mod/mod_mime.html#removeoutputfilter">RemoveOutputFilter</a></code>.</p>
153
154 <p>La méthode Dynamique permet une configuration dynamique des filtres en
155 sortie à la fois statique et flexible, comme discuté dans la page
156 <code class="module"><a href="./mod/mod_filter.html">mod_filter</a></code>.
157 Les directives correspondantes sont
158     <code class="directive"><a href="./mod/mod_filter.html#filterchain">FilterChain</a></code>,
159     <code class="directive"><a href="./mod/mod_filter.html#filterdeclare">FilterDeclare</a></code>, et
160     <code class="directive"><a href="./mod/mod_filter.html#filterprovider">FilterProvider</a></code>.</p>
161
162 <p>Une autre directive <code class="directive"><a href="./mod/mod_filter.html#addoutputfilterbytype">AddOutputFilterByType</a></code> est encore supportée,
163 mais obsolète. Utilisez la
164 configuration dynamique à la place.</p>
165
166   </div></div>
167 <div class="bottomlang">
168 <p><span>Langues Disponibles: </span><a href="./en/filter.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
169 <a href="./es/filter.html" hreflang="es" rel="alternate" title="Español">&nbsp;es&nbsp;</a> |
170 <a href="./fr/filter.html" title="Français">&nbsp;fr&nbsp;</a> |
171 <a href="./ja/filter.html" hreflang="ja" rel="alternate" title="Japanese">&nbsp;ja&nbsp;</a> |
172 <a href="./ko/filter.html" hreflang="ko" rel="alternate" title="Korean">&nbsp;ko&nbsp;</a> |
173 <a href="./tr/filter.html" hreflang="tr" rel="alternate" title="Türkçe">&nbsp;tr&nbsp;</a></p>
174 </div><div id="footer">
175 <p class="apache">Copyright 2012 The Apache Software Foundation.<br />Autorisé sous <a href="http://www.apache.org/licenses/LICENSE-2.0">Apache License, Version 2.0</a>.</p>
176 <p class="menu"><a href="./mod/">Modules</a> | <a href="./mod/directives.html">Directives</a> | <a href="./faq/">FAQ</a> | <a href="./glossary.html">Glossaire</a> | <a href="./sitemap.html">Plan du site</a></p></div><script type="text/javascript">
177     if (typeof(prettyPrint) !== undefined) {
178         prettyPrint();
179     }
180 </script>
181 </body></html>