]> granicus.if.org Git - apache/blob - docs/manual/rewrite/intro.html.fr
Rebuild.
[apache] / docs / manual / rewrite / intro.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 <meta content="text/html; charset=ISO-8859-1" http-equiv="Content-Type" />
5 <!--
6         XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
7               This file is generated from xml source: DO NOT EDIT
8         XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
9       -->
10 <title>Introduction au module Apache mod_rewrite - Serveur Apache HTTP Version 2.4</title>
11 <link href="../style/css/manual.css" rel="stylesheet" media="all" type="text/css" title="Main stylesheet" />
12 <link href="../style/css/manual-loose-100pc.css" rel="alternate stylesheet" media="all" type="text/css" title="No Sidebar - Default font size" />
13 <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" />
14 <script src="../style/scripts/prettify.min.js" type="text/javascript">
15 </script>
16
17 <link href="../images/favicon.ico" rel="shortcut icon" /></head>
18 <body id="manual-page"><div id="page-header">
19 <p class="menu"><a href="../mod/">Modules</a> | <a href="../mod/directives.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>
20 <p class="apache">Serveur Apache HTTP Version 2.4</p>
21 <img alt="" src="../images/feather.png" /></div>
22 <div class="up"><a href="./"><img title="&lt;-" alt="&lt;-" src="../images/left.gif" /></a></div>
23 <div id="path">
24 <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.4</a> &gt; <a href="./">Rewrite</a></div><div id="page-content"><div id="preamble"><h1>Introduction au module Apache mod_rewrite</h1>
25 <div class="toplang">
26 <p><span>Langues Disponibles: </span><a href="../en/rewrite/intro.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
27 <a href="../fr/rewrite/intro.html" title="Français">&nbsp;fr&nbsp;</a></p>
28 </div>
29
30 <p>Ce document est un complément à la <a href="../mod/mod_rewrite.html">documentation de référence</a> du module
31 <code class="module"><a href="../mod/mod_rewrite.html">mod_rewrite</a></code>. Il décrit les concepts de base dont la
32 connaissance est nécessaire pour l'utilisation de
33 <code class="module"><a href="../mod/mod_rewrite.html">mod_rewrite</a></code>. D'autres documents entrent d'avantage dans
34 les détails, mais celui-ci devrait aider le débutant à se mouiller les
35 pieds.
36 </p>
37 </div>
38 <div id="quickview"><a href="https://www.apache.org/foundation/contributing.html" class="badge"><img src="https://www.apache.org/images/SupportApache-small.png" alt="Support Apache!" /></a><ul id="toc"><li><img alt="" src="../images/down.gif" /> <a href="#introduction">Introduction</a></li>
39 <li><img alt="" src="../images/down.gif" /> <a href="#regex">Expressions rationnelles</a></li>
40 <li><img alt="" src="../images/down.gif" /> <a href="#rewriterule">Les bases des règles de réécriture</a></li>
41 <li><img alt="" src="../images/down.gif" /> <a href="#flags">Drapeaux de réécriture</a></li>
42 <li><img alt="" src="../images/down.gif" /> <a href="#rewritecond">Conditions de réécriture</a></li>
43 <li><img alt="" src="../images/down.gif" /> <a href="#rewritemap">Tables de réécriture</a></li>
44 <li><img alt="" src="../images/down.gif" /> <a href="#htaccess">Fichiers .htaccess</a></li>
45 </ul><h3>Voir aussi</h3><ul class="seealso"><li><a href="../mod/mod_rewrite.html">Documentation du
46 module mod_rewrite</a></li><li><a href="remapping.html">Redirection and remise en
47 correspondance</a></li><li><a href="access.html">Contrôle d'accès</a></li><li><a href="vhosts.html">Serveurs virtuels</a></li><li><a href="proxy.html">Mise en cache</a></li><li><a href="rewritemap.html">Utilisation de RewriteMap</a></li><li><a href="advanced.html">Techniques avancées</a></li><li><a href="avoid.html">Quand ne pas utiliser mod_rewrite</a></li><li><a href="#comments_section">Commentaires</a></li></ul></div>
48 <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
49 <div class="section">
50 <h2><a name="introduction" id="introduction">Introduction</a></h2>
51 <p>Le module Apache <code class="module"><a href="../mod/mod_rewrite.html">mod_rewrite</a></code> est un module puissant
52 et sophistiqué qui permet la réécriture des URLs. Grâce à lui, vous
53 pouvez effectuer quasiment tous les types de réécriture d'URLs dont vous
54 avez besoin. Il est cependant assez complexe, et peut paraître
55 intimidant au débutant. Certains ont aussi tendance à traiter les
56 règles de réécriture comme des incantations magiques, et à les utiliser
57 sans vraiment comprendre leur manière d'agir.</p>
58
59 <p>Ce document a pour ambition d'être suffisamment explicite pour
60 permettre la compréhension, et non la copie en aveugle, de ce qui suit.
61 </p>
62
63 <p>Gardez à l'esprit que de nombreuses tâches de manipulation d'URLs
64 courantes n'ont pas besoin de la puissance et de la complexité de
65 <code class="module"><a href="../mod/mod_rewrite.html">mod_rewrite</a></code>. Pour les tâches simples, voir
66 <code class="module"><a href="../mod/mod_alias.html">mod_alias</a></code> et la documentation sur la <a href="../urlmapping.html">Mise en correspondance des URLs avec le
67 système de fichiers</a>.</p>
68
69 <p>Enfin, avant de procéder, assurez-vous d'avoir configuré le niveau de
70 journalisation de <code class="module"><a href="../mod/mod_rewrite.html">mod_rewrite</a></code> à un des niveaux de trace
71 via la directive <code class="directive"><a href="../mod/core.html#loglevel">LogLevel</a></code>. Bien que
72 ceci risque de vous submerger sous une énorme quantité d'informations,
73 le débogage des problèmes avec la configuration de
74 <code class="module"><a href="../mod/mod_rewrite.html">mod_rewrite</a></code> est à ce prix car vous verrez alors
75 exactement comment chaque règle est traitée.</p>
76
77 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
78 <div class="section">
79 <h2><a name="regex" id="regex">Expressions rationnelles</a></h2>
80
81 <p>mod_rewrite utilise le vocabulaire des <a href="http://pcre.org/">Expressions rationnelles compatibles Perl</a>.
82 Ce document n'a pas pour prétention d'être une référence détaillée des
83 expressions rationnelles. A cet effet, nous recommandons les <a href="http://pcre.org/pcre.txt">pages de manuel de PCRE</a>, la <a href="http://perldoc.perl.org/perlre.html">page de manuel des
84 expressions rationnelles Perl</a>, et l'ouvrage <a href="http://shop.oreilly.com/product/9780596528126.do">Mastering
85 Regular Expressions, by Jeffrey Friedl</a>.</p>
86
87 <p>Dans ce document, nous avons pour but de vous fournir suffisamment de
88 vocabulaire des expressions rationnelles pour vous mettre le pied à
89 l'étrier, sans être dépassé, en espérant que les directives <code class="directive"><a href="../mod/mod_rewrite.html#rewriterule">RewriteRule</a></code> vous apparaîtront comme des
90 formules scientifiques, plutôt que comme des incantations magiques.</p>
91
92 <h3><a name="regexvocab" id="regexvocab">Vocabulaire des expressions rationnelles</a></h3>
93
94 <p>Vous trouverez dans ce qui suit le minimum à connaître pour être en
95 mesure d'écrire des expressions rationnelles et des règles <code class="directive"><a href="../mod/mod_rewrite.html#rewriterule">RewriteRule</a></code>. Ceci ne représente
96 certainement pas un vocabulaire des expressions rationnelles complet,
97 mais constitue un bon point de départ, et devrait vous aider à
98 déchiffrer les expressions rationnelles simples, et à écrire vos propres
99 expressions.</p>
100
101 <table>
102 <tr>
103 <th>Motif</th>
104 <th>Signification</th>
105 <th>Exemple</th>
106 </tr>
107
108 <tr><td><code>.</code></td><td>Correspond à tout caractère unique
109 </td><td><code>c.t</code> correspondra à <code>cat</code>,
110 <code>cot</code>, <code>cut</code>, etc.</td></tr>
111 <tr><td><code>+</code></td><td>Répète le caractère de correspondance
112 précédent une ou plusieurs fois</td>
113 <td><code>a+</code> correspond à <code>a</code>, <code>aa</code>,
114 <code>aaa</code>, etc.</td></tr>
115 <tr><td><code>*</code></td><td>Répète le caractère de correspondance
116 précédent zéro ou plusieurs fois</td>
117 <td><code>a*</code> correspond à tout ce à quoi correspond
118 <code>a+</code>, mais correspond aussi à la chaîne vide.</td></tr>
119 <tr><td><code>?</code></td><td>Rend la correspondance optionnelle.</td><td>
120 <code>colou?r</code> correspondra à <code>color</code> et <code>colour</code>.</td>
121 </tr>
122 <tr><td><code>^</code></td><td>Appelé ancrage, correspond au début de la
123 chaîne</td>
124 <td><code>^a</code> correspond à une chaîne qui commence par
125 <code>a</code></td></tr>
126 <tr><td><code>$</code></td><td>L'autre ancrage, correspond à la fin de
127 la chaîne.</td>
128 <td><code>a$</code> correspond à une chaîne qui se termine par
129 <code>a</code>.</td></tr>
130 <tr><td><code>( )</code></td><td>Regroupe plusieurs caractères en une
131 seule entité, et conserve une correspondance à des fins d'utilisation
132 dans une référence arrière.</td>
133 <td><code>(ab)+</code>
134 correspond à <code>ababab</code> - à savoir, le <code>+</code>
135 s'applique au groupe.
136 Pour plus de détails sur les références arrières, voir <a href="#InternalBackRefs">ci-dessous</a>.</td></tr>
137 <tr><td><code>[ ]</code></td><td>Une classe de caractères - correspond à
138 un des caractères de la classe</td>
139 <td><code>c[uoa]t</code> correspond à <code>cut</code>,
140 <code>cot</code> ou <code>cat</code>.</td></tr>
141 <tr><td><code>[^ ]</code></td><td>Négation de la classe de caractères -
142 correspond à tout caractère ne faisant pas partie de la classe</td>
143 <td><code>c[^/]t</code> correspond à <code>cat</code> ou
144 <code>c=t</code> mais pas à <code>c/t</code></td></tr>
145 </table>
146
147 <p>Avec <code class="module"><a href="../mod/mod_rewrite.html">mod_rewrite</a></code>, le caractère <code>!</code> peut
148 préfixer une expression rationnelle afin d'en exprimer la négation.
149 Autrement dit, une chaîne ne correspondra que si elle ne correspond pas
150 à l'expression située après le <code>!</code>.</p>
151
152
153
154 <h3><a name="InternalBackRefs" id="InternalBackRefs">Disponibilité des références
155 arrières dans les expressions rationnelles</a></h3>
156
157       <p>Vous devez vous souvenir d'une chose importante : chaque fois
158       que vous utilisez des parenthèses dans un <em>Modèle</em> ou dans
159       un des <em>modèles de conditions</em>, des références arrières
160       sont créées en interne et peuvent être rappelées via les chaînes
161       <code>$N</code> et <code>%N</code> (voir ci-dessous). Ces
162       références sont disponibles lors de la création
163       de la chaîne de substitution d'une directive
164       <code class="directive"><a href="../mod/mod_rewrite.html#rewriterule">RewriteRule</a></code> ou de la
165       chaîne de test d'une directive <code class="directive"><a href="../mod/mod_rewrite.html#rewritecond">RewriteCond</a></code>.</p>
166       <p>Les captures dans les modèles de directives <code class="directive"><a href="../mod/mod_rewrite.html#rewriterule">RewriteRule</a></code> sont paradoxalement
167       disponibles dans toutes les directives <code class="directive"><a href="../mod/mod_rewrite.html#rewritecond">RewriteCond</a></code> qui précèdent, car
168       les expressions des directives <code class="directive"><a href="../mod/mod_rewrite.html#rewriterule">RewriteRule</a></code> sont évaluées avant
169       les conditions individuelles.</p>
170        
171       
172       <p>La figure 1 montre à quels endroits les
173       références arrières sont suceptibles
174       d'être développées, et illustre le flux des comparaisons
175       effectuées par les règles RewriteRule et
176       RewriteCond. Dans les chapitres suivants, nous examinerons comment
177       utiliser ces références arrières, donc ne vous affolez pas si
178       elles vous paraissent un peu exotiques au premier abord.</p>
179
180 <p class="figure">
181       <img src="../images/rewrite_backreferences.png" alt="Flux des comparaisons effectuées par les règles RewriteRule       et RewriteCond" /><br />
182       <dfn>Figure 1 :</dfn> Le cheminement d'une référence arrière à
183       travers une règle.<br />
184       Dans cet exemple, une requête pour <code>/test/1234</code> serait
185       transformée en
186       <code>/admin.foo?page=test&amp;id=1234&amp;host=admin.example.com</code>.
187 </p>
188
189
190 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
191 <div class="section">
192 <h2><a name="rewriterule" id="rewriterule">Les bases des règles de réécriture</a></h2>
193 <p>Une règle de réécriture <code class="directive"><a href="../mod/mod_rewrite.html#rewriterule">RewriteRule</a></code> est constituée de trois
194 arguments séparés par des espaces. Les arguments sont :</p>
195 <ol>
196 <li><var>Modèle</var>: le modèle des URLs auxquelles la règle doit
197 s'appliquer;</li>
198 <li><var>Substitution</var>: vers quoi la requête correspondante doit être
199 transformée;</li>
200 <li><var>[drapeaux]</var>: options affectant la requête réécrite.</li>
201 </ol>
202
203 <p>Le <var>Modèle</var> est une <a href="#regex">expression
204 rationnelle</a>. Au sein de la première règle de réécriture, ou jusqu'à
205 ce qu'une substitution survienne, elle est comparée au chemin de
206 l'URL de la requête entrante (la
207 partie située après le nom d'hôte mais avant tout point d'interrogation
208 qui indique le début d'une chaîne de paramètres de
209 requête) ou, dans un contexte de répertoire, au chemin de la
210 requête relativement au répertoire pour lequel la
211 règle est définie. Lorsqu'une substitution a eu lieu, les
212 règles suivantes effectuent leurs comparaisons par rapport à la valeur
213 substituée.</p>
214
215 <p class="figure">
216       <img src="../images/syntax_rewriterule.png" alt="Syntaxe de la directive RewriteRule" /><br />
217       <dfn>Figure 2 :</dfn> Syntaxe de la directive RewriteRule.
218 </p>
219
220 <p>La chaîne de <var>Substitution</var> peut, quant à elle, être de
221 trois types :</p>
222
223 <dl>
224 <dt>Un chemin complet du système de fichiers vers une ressource</dt>
225 <dd>
226 <pre class="prettyprint lang-config">RewriteRule "^/jeux" "/usr/local/jeux/web"</pre>
227
228 <p>Ceci peut faire correspondre une requête à toute localisation voulue de
229 votre système de fichiers, un peu comme la directive <code class="directive"><a href="../mod/mod_alias.html#alias">Alias</a></code>.</p>
230 </dd>
231
232 <dt>Un chemin web vers une ressource</dt>
233 <dd>
234 <pre class="prettyprint lang-config">RewriteRule "^/foo$" "/bar"</pre>
235
236 <p>Si la directive <code class="directive"><a href="../mod/core.html#documentroot">DocumentRoot</a></code> a
237 pour valeur <code>/usr/local/apache2/htdocs</code>, cette règle va faire
238 correspondre les requêtes pour <code>http://example.com/foo</code> au
239 chemin <code>/usr/local/apache2/htdocs/bar</code>.</p>
240 </dd>
241
242 <dt>Une URL absolue</dt>
243 <dd>
244 <pre class="prettyprint lang-config">RewriteRule "^/produits/vues$" "http://site2.example.com/voirproduits.html" [R]</pre>
245
246 <p>Ceci informe le client qu'il doit effectuer une nouvelle requête vers
247 l'URL spécifiée.</p>
248 </dd>
249 </dl>
250
251 <p>La chaîne de <var>Substitution</var> peut aussi contenir des
252 <em>références arrières</em> vers des parties du chemin d'URL entrant
253 correspondant au <var>Modèle</var>. Considérons ce qui suit :</p>
254 <pre class="prettyprint lang-config">RewriteRule "^/produits/(.*)/view$" "/var/web/produitsdb/$1"</pre>
255
256 <p>La variable <code>$1</code> sera remplacée par tout texte
257 correspondant à l'expression située entre les parenthèses dans le
258 <var>Modèle</var>. Par exemple, une requête pour
259 <code>http://example.com/produits/r14df/vue</code> correspondra au
260 chemin <code>/var/web/produitsdb/r14df</code>.</p>
261
262 <p>S'il y a plus d'une expression entre parenthèses, elle seront
263 accessibles selon leur ordre d'apparition via les variables
264 <code>$1</code>, <code>$2</code>, <code>$3</code>, etc...</p>
265
266
267 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
268 <div class="section">
269 <h2><a name="flags" id="flags">Drapeaux de réécriture</a></h2>
270 <p>Le comportement d'une règle <code class="directive"><a href="../mod/mod_rewrite.html#rewriterule">RewriteRule</a></code> peut être modifié par la
271 présence d'un ou plusieurs drapeaux en fin de règle. Par exemple, les
272 conditions de correspondance d'une règle peuvent être rendues
273 insensibles à la casse par la présence du drapeau <code>[NC]</code> :
274 </p>
275 <pre class="prettyprint lang-config">RewriteRule "^puppy.html" "petitchien.html" [NC]</pre>
276
277
278 <p>Pour une liste des drapeaux disponibles, leurs significations, et des
279 exemples, voir le document <a href="flags.html">Drapeaux de
280 réécriture</a>.</p>
281
282 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
283 <div class="section">
284 <h2><a name="rewritecond" id="rewritecond">Conditions de réécriture</a></h2>
285 <p>Il est possible d'utiliser une ou plusieurs directives <code class="directive"><a href="../mod/mod_rewrite.html#rewritecond">RewriteCond</a></code> pour restreindre les types
286 de requêtes auxquelles devra s'appliquer la règle <code class="directive"><a href="../mod/mod_rewrite.html#rewriterule">RewriteRule</a></code> suivante. Le premier
287 argument est une variable décrivant une caractéristique de la requête,
288 le second argument est une <a href="#regex">expression rationnelle</a>
289 qui doit correspondre à la variable, et un troisième argument optionnel
290 est une liste de drapeaux qui modifient la manière dont la
291 correspondance est évaluée.</p>
292
293 <p class="figure">
294       <img src="../images/syntax_rewritecond.png" alt="Syntaxe de la directive RewriteCond" /><br />
295       <dfn>Figure 3 :</dfn> Syntaxe de la directive RewriteCond
296 </p>
297
298
299 <p>Par exemple, pour renvoyer toutes les requêtes en provenance d'une
300 certaine tranche d'adresses IP vers un autre serveur, vous pouvez
301 utiliser :</p>
302 <pre class="prettyprint lang-config">RewriteCond "%{REMOTE_ADDR}" "^10\.2\."
303 RewriteRule "(.*)" "http://intranet.example.com$1"</pre>
304
305
306 <p>Si vous spécifiez plus d'une directive <code class="directive"><a href="../mod/mod_rewrite.html#rewritecond">RewriteCond</a></code>, ces directives
307 doivent toutes être satisfaites pour que la règle <code class="directive"><a href="../mod/mod_rewrite.html#rewriterule">RewriteRule</a></code> suivante s'applique. Par exemple,
308 pour interdire les requêtes qui contiennent le mot "hack" dans la chaîne
309 de requête, sauf si elles contiennent aussi un cookie contenant le mot
310 "go", vous pouvez utiliser :</p>
311 <pre class="prettyprint lang-config">RewriteCond "%{QUERY_STRING}" "hack"
312 RewriteCond "%{HTTP_COOKIE}" "!go"
313 RewriteRule "." "-" [F]</pre>
314
315 <p>Notez que le point d'exclamation indique une correspondance négative
316 ; ainsi, la règle n'est appliquée que si le cookie ne contient pas "go"</p>
317
318 <p>Les correspondances dans les expressions rationnelles contenues dans
319 les directives <code class="directive"><a href="../mod/mod_rewrite.html#rewritecond">RewriteCond</a></code>
320 peuvent constituer des parties de la chaîne de <var>Substitution</var>
321 de la règle <code class="directive"><a href="../mod/mod_rewrite.html#rewriterule">RewriteRule</a></code> via
322 les variables <code>%1</code>, <code>%2</code>, etc... Par
323 exemple, ce qui suit va diriger la requête vers un répertoire différent
324 en fonction du nom d'hôte utilisé pour accéder au site :</p>
325 <pre class="prettyprint lang-config">RewriteCond "%{HTTP_HOST}" "(.*)"
326 RewriteRule "^/(.*)" "/sites/%1/$1"</pre>
327
328 <p>Si la requête concernait <code>http://example.com/foo/bar</code>,
329 alors <code>%1</code> contiendrait <code>example.com</code> et
330 <code>$1</code> contiendrait <code>foo/bar</code>.</p>
331
332
333
334 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
335 <div class="section">
336 <h2><a name="rewritemap" id="rewritemap">Tables de réécriture</a></h2>
337
338 <p>La directive <code class="directive"><a href="../mod/mod_rewrite.html#rewritemap">RewriteMap</a></code>
339 permet en quelque sorte de faire appel à une fonction externe pour
340 effectuer la réécriture à votre place. Tout ceci est décrit plus en
341 détails dans la <a href="rewritemap.html">Documentation
342 supplémentaire sur RewriteMap</a>.</p>
343 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
344 <div class="section">
345 <h2><a name="htaccess" id="htaccess">Fichiers .htaccess</a></h2>
346
347 <p>La réécriture est en général définie au niveau de la configuration du
348 serveur principal (en dehors de toute section <code class="directive"><a href="../mod/core.html#directory">&lt;Directory&gt;</a></code>) ou dans une section  <code class="directive"><a href="../mod/core.html#virtualhost">&lt;VirtualHost&gt;</a></code>. Il s'agit là de la
349 manière la plus simple de mettre en oeuvre la réécriture et nous la
350 recommandons. Il est possible, cependant, de mettre en oeuvre la
351 réécriture au sein d'une section <code class="directive"><a href="../mod/core.html#directory">&lt;Directory&gt;</a></code> ou d'un fichier <a href="../howto/htaccess.html"><code>.htaccess</code></a> ; ce type de
352 configuration est cependant plus complexe. Cette technique est appelée
353 réécriture par répertoire.</p>
354
355 <p>La principale différence avec les réécritures au niveau du serveur réside
356 dans le fait que le préfixe du chemin du répertoire contenant le fichier
357 <code>.htaccess</code> est supprimé avant la mise en correspondance dans
358 la règle <code class="directive"><a href="../mod/mod_rewrite.html#rewriterule">RewriteRule</a></code>. De
359 plus, on doit utiliser la directive <code class="directive"><a href="../mod/mod_rewrite.html#rewritebase">RewriteBase</a></code> pour s'assurer que la
360 requête est correctement mise en correspondance.</p>
361
362 </div></div>
363 <div class="bottomlang">
364 <p><span>Langues Disponibles: </span><a href="../en/rewrite/intro.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
365 <a href="../fr/rewrite/intro.html" title="Français">&nbsp;fr&nbsp;</a></p>
366 </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>
367 <script type="text/javascript"><!--//--><![CDATA[//><!--
368 var comments_shortname = 'httpd';
369 var comments_identifier = 'http://httpd.apache.org/docs/2.4/rewrite/intro.html';
370 (function(w, d) {
371     if (w.location.hostname.toLowerCase() == "httpd.apache.org") {
372         d.write('<div id="comments_thread"><\/div>');
373         var s = d.createElement('script');
374         s.type = 'text/javascript';
375         s.async = true;
376         s.src = 'https://comments.apache.org/show_comments.lua?site=' + comments_shortname + '&page=' + comments_identifier;
377         (d.getElementsByTagName('head')[0] || d.getElementsByTagName('body')[0]).appendChild(s);
378     }
379     else { 
380         d.write('<div id="comments_thread">Comments are disabled for this page at the moment.<\/div>');
381     }
382 })(window, document);
383 //--><!]]></script></div><div id="footer">
384 <p class="apache">Copyright 2017 The Apache Software Foundation.<br />Autorisé sous <a href="http://www.apache.org/licenses/LICENSE-2.0">Apache License, Version 2.0</a>.</p>
385 <p class="menu"><a href="../mod/">Modules</a> | <a href="../mod/directives.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[//><!--
386 if (typeof(prettyPrint) !== 'undefined') {
387     prettyPrint();
388 }
389 //--><!]]></script>
390 </body></html>