]> granicus.if.org Git - apache/blob - docs/manual/filter.html.fr
Rebuild.
[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 Version 2.5</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.min.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/quickreference.html">Directives</a> | <a href="http://wiki.apache.org/httpd/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><ul class="seealso"><li><a href="#comments_section">Commentaires</a></li></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, selon
50 vos souhaits.
51 Ces traitements sont tout à fait indépendants des traditionnelles phases
52 de traitement des requêtes.</p>
53 <p class="figure">
54 <img src="images/filter_arch.png" width="569" height="392" alt="les filtres peuvent s'enchaîner, perpendiculairement au traitement des requêtes" />
55 </p>
56 <p>Voici quelques exemples de filtrage avec la distribution standard d'Apache:</p>
57 <ul>
58 <li><code class="module"><a href="./mod/mod_include.html">mod_include</a></code>, implémente les inclusions côté serveur.</li>
59 <li><code class="module"><a href="./mod/mod_ssl.html">mod_ssl</a></code>, implémente le cryptage SSL (https).</li>
60 <li><code class="module"><a href="./mod/mod_deflate.html">mod_deflate</a></code>, implémente la compression/décompression
61 à la volée.</li>
62 <li><code class="module"><a href="./mod/mod_charset_lite.html">mod_charset_lite</a></code>, transcodage entre différents
63 jeux de caractères.</li>
64 <li><code class="module"><a href="./mod/mod_ext_filter.html">mod_ext_filter</a></code>, utilisation d'un programme externe
65 comme filtre.</li>
66 </ul>
67 <p>Apache utilise aussi plusieurs filtres en interne pour accomplir des tâches
68 comme le découpage des grosses requêtes (chunking) et la gestion des
69 requêtes portant sur une partie d'un fichier (byte-range).</p>
70
71 <p>Un grand choix d'applications sont implémentées par des modules de filtrage
72 tiers disponibles à <a href="http://modules.apache.org/">modules.apache.org</a> entre autres.
73 En voici quelques exemples :</p>
74
75 <ul>
76 <li>Traitement et réécriture HTML et XML</li>
77 <li>Transformations XSLT et inclusions XML (XIncludes)</li>
78 <li>Support de l'espace de nommage XML</li>
79 <li>Gestion du chargement de fichier et décodage des formulaires HTML</li>
80 <li>Traitement d'image</li>
81 <li>Protection des applications vulnérables comme les scripts PHP</li>
82 <li>Edition de texte par Chercher/Remplacer</li>
83 </ul>
84 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
85 <div class="section">
86 <h2><a name="smart" id="smart">Filtrage intelligent</a></h2>
87
88 <p class="figure">
89 <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" />
90 </p>
91 <p><code class="module"><a href="./mod/mod_filter.html">mod_filter</a></code>, inclus dans les version 2.1 et supérieures
92 d'Apache, permet de configurer la chaîne de filtrage dynamiquement
93 à l'exécution.
94 Ainsi par exemple, vous pouvez définir un proxy pour réécrire du code HTML
95 avec un filtre HTML et traiter des images JPEG avec un filtre totalement
96 séparé, bien que le proxy ne possède aucune information préliminaire
97 sur ce que le serveur à l'origine des données à filtrer va envoyer.
98 Ceci fonctionne grâce à l'utilisation d'un gestionnaire de filtre,
99 qui distribue les tâches à différents fournisseurs de filtrage en fonction
100 du contenu réel à filtrer à l'exécution.  Tout filtre peut se voir soit
101 inséré directement dans la chaîne et lancé inconditionnellement, soit
102 utilisé comme un fournisseur de filtrage et inséré dynamiquement.
103 Par exemple,</p>
104 <ul>
105 <li>un filtre de traitement HTML sera lancé uniquement si le contenu est
106 de type text/html ou application/xhtml+xml</li>
107 <li>Un filtre de compression sera lancé uniquement si les données en entrée
108 sont de type compressible et non déjà compressées</li>
109 <li>Un filtre de conversion de jeux de caractères ne sera inséré que si
110 le document texte n'est pas déjà dans le jeu de caractères voulu</li>
111 </ul>
112 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
113 <div class="section">
114 <h2><a name="service" id="service">Présentation des filtres en tant que service HTTP</a></h2>
115
116
117 <p>Les filtres permettent de traiter les requêtes des clients avant
118 traitement par le serveur, ainsi que les contenus issus du serveur avant de les renvoyer
119 au client. Le module <code class="module"><a href="./mod/mod_reflector.html">mod_reflector</a></code> permet aussi
120 d'utiliser les filtres pour traiter les requêtes des clients avant de
121 les renvoyer directement à ces derniers.</p>
122
123 <p>Le module <code class="module"><a href="./mod/mod_reflector.html">mod_reflector</a></code> reçoit les requêtes POST des
124 clients, et en répercute le corps dans la requête POST constituant la
125 réponse, lors de l'envoi de cette dernière au client en passant à travers la
126 pile de filtres en sortie.</p>
127
128 <p>Cette technique peut être utilisée comme alternative à un service web
129 s'exécutant à l'intérieur de la pile d'un serveur d'applications, où un
130 filtre en sortie effectue la transformation requise sur le corps de la
131 requête. Par exemple, on peut utiliser le module
132 <code class="module"><a href="./mod/mod_deflate.html">mod_deflate</a></code> pour fournir un service général de
133 compression ; un filtre de transformation d'images peut aussi se voir
134 mué en service de transformation d'images.</p>
135
136 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
137 <div class="section">
138 <h2><a name="using" id="using">Utilisation des filtres</a></h2>
139
140 <p>Il y a deux manières d'utiliser le filtrage : Simple et Dynamique.
141 En général, vous utiliserez l'une ou l'autre méthode; le mélange des deux
142 peut avoir des conséquences inattendues (bien que le filtrage simple en entrée
143 puisse être associé sans problème avec le filtrage simple ou dynamique
144 en sortie).</p>
145 <p>La méthode Simple est la seule permettant de configurer les filtres
146 en entrée, et suffit pour les filtres en sortie pour lesquels vous avez besoin
147 d'une chaîne de filtres statique.
148 Les directives correspondantes sont
149     <code class="directive"><a href="./mod/core.html#setinputfilter">SetInputFilter</a></code>,
150     <code class="directive"><a href="./mod/core.html#setoutputfilter">SetOutputFilter</a></code>,
151     <code class="directive"><a href="./mod/mod_mime.html#addinputfilter">AddInputFilter</a></code>,
152     <code class="directive"><a href="./mod/mod_mime.html#addoutputfilter">AddOutputFilter</a></code>,
153     <code class="directive"><a href="./mod/mod_mime.html#removeinputfilter">RemoveInputFilter</a></code>, et
154     <code class="directive"><a href="./mod/mod_mime.html#removeoutputfilter">RemoveOutputFilter</a></code>.</p>
155
156 <p>La méthode Dynamique permet une configuration dynamique des filtres en
157 sortie à la fois statique et flexible, comme discuté dans la page
158 <code class="module"><a href="./mod/mod_filter.html">mod_filter</a></code>.
159 Les directives correspondantes sont
160     <code class="directive"><a href="./mod/mod_filter.html#filterchain">FilterChain</a></code>,
161     <code class="directive"><a href="./mod/mod_filter.html#filterdeclare">FilterDeclare</a></code>, et
162     <code class="directive"><a href="./mod/mod_filter.html#filterprovider">FilterProvider</a></code>.</p>
163
164 <p>Une autre directive <code class="directive"><a href="./mod/mod_filter.html#addoutputfilterbytype">AddOutputFilterByType</a></code> est encore supportée,
165 mais obsolète. Utilisez la
166 configuration dynamique à la place.</p>
167
168   </div></div>
169 <div class="bottomlang">
170 <p><span>Langues Disponibles: </span><a href="./en/filter.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
171 <a href="./es/filter.html" hreflang="es" rel="alternate" title="Español">&nbsp;es&nbsp;</a> |
172 <a href="./fr/filter.html" title="Français">&nbsp;fr&nbsp;</a> |
173 <a href="./ja/filter.html" hreflang="ja" rel="alternate" title="Japanese">&nbsp;ja&nbsp;</a> |
174 <a href="./ko/filter.html" hreflang="ko" rel="alternate" title="Korean">&nbsp;ko&nbsp;</a> |
175 <a href="./tr/filter.html" hreflang="tr" rel="alternate" title="Türkçe">&nbsp;tr&nbsp;</a></p>
176 </div><div class="top"><a href="#page-header"><img src="./images/up.gif" alt="top" /></a></div><div class="section"><h2><a id="comments_section" name="comments_section">Commentaires</a></h2><div class="warning"><strong>Notice:</strong><br />This is not a Q&amp;A section. Comments placed here should be pointed towards suggestions on improving the documentation or server, and may be removed again by our moderators if they are either implemented or considered invalid/off-topic. Questions on how to manage the Apache HTTP Server should be directed at either our IRC channel, #httpd, on Freenode, or sent to our <a href="http://httpd.apache.org/lists.html">mailing lists</a>.</div>
177 <script type="text/javascript"><!--//--><![CDATA[//><!--
178 var comments_shortname = 'httpd';
179 var comments_identifier = 'http://httpd.apache.org/docs/trunk/filter.html';
180 (function(w, d) {
181     if (w.location.hostname.toLowerCase() == "httpd.apache.org") {
182         d.write('<div id="comments_thread"><\/div>');
183         var s = d.createElement('script');
184         s.type = 'text/javascript';
185         s.async = true;
186         s.src = 'https://comments.apache.org/show_comments.lua?site=' + comments_shortname + '&page=' + comments_identifier;
187         (d.getElementsByTagName('head')[0] || d.getElementsByTagName('body')[0]).appendChild(s);
188     }
189     else {
190         d.write('<div id="comments_thread">Comments are disabled for this page at the moment.<\/div>');
191     }
192 })(window, document);
193 //--><!]]></script></div><div id="footer">
194 <p class="apache">Copyright 2014 The Apache Software Foundation.<br />Autorisé sous <a href="http://www.apache.org/licenses/LICENSE-2.0">Apache License, Version 2.0</a>.</p>
195 <p class="menu"><a href="./mod/">Modules</a> | <a href="./mod/quickreference.html">Directives</a> | <a href="http://wiki.apache.org/httpd/FAQ">FAQ</a> | <a href="./glossary.html">Glossaire</a> | <a href="./sitemap.html">Plan du site</a></p></div><script type="text/javascript"><!--//--><![CDATA[//><!--
196 if (typeof(prettyPrint) !== 'undefined') {
197     prettyPrint();
198 }
199 //--><!]]></script>
200 </body></html>