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" />
6 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
7 This file is generated from xml source: DO NOT EDIT
8 XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
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">
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="<-" alt="<-" src="../images/left.gif" /></a></div>
24 <a href="http://www.apache.org/">Apache</a> > <a href="http://httpd.apache.org/">Serveur HTTP</a> > <a href="http://httpd.apache.org/docs/">Documentation</a> > <a href="../">Version 2.4</a> > <a href="./">Rewrite</a></div><div id="page-content"><div id="preamble"><h1>Introduction au module Apache mod_rewrite</h1>
26 <p><span>Langues Disponibles: </span><a href="../en/rewrite/intro.html" hreflang="en" rel="alternate" title="English"> en </a> |
27 <a href="../fr/rewrite/intro.html" title="Français"> fr </a></p>
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
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>
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>
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.
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>
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>
77 </div><div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
79 <h2><a name="regex" id="regex">Expressions rationnelles</a></h2>
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>
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>
92 <h3><a name="regexvocab" id="regexvocab">Vocabulaire des expressions rationnelles</a></h3>
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
104 <th>Signification</th>
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>
122 <tr><td><code>^</code></td><td>Appelé ancrage, correspond au début de la
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
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>
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>
154 <h3><a name="InternalBackRefs" id="InternalBackRefs">Disponibilité des références
155 arrières dans les expressions rationnelles</a></h3>
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>
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>
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
186 <code>/admin.foo?page=test&id=1234&host=admin.example.com</code>.
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>
196 <li><var>Modèle</var>: le modèle des URLs auxquelles la règle doit
198 <li><var>Substitution</var>: vers quoi la requête correspondante doit être
200 <li><var>[drapeaux]</var>: options affectant la requête réécrite.</li>
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
216 <img src="../images/syntax_rewriterule.png" alt="Syntaxe de la directive RewriteRule" /><br />
217 <dfn>Figure 2 :</dfn> Syntaxe de la directive RewriteRule.
220 <p>La chaîne de <var>Substitution</var> peut, quant à elle, être de
224 <dt>Un chemin complet du système de fichiers vers une ressource</dt>
226 <pre class="prettyprint lang-config">RewriteRule "^/jeux" "/usr/local/jeux/web"</pre>
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>
232 <dt>Un chemin web vers une ressource</dt>
234 <pre class="prettyprint lang-config">RewriteRule "^/foo$" "/bar"</pre>
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>
242 <dt>Une URL absolue</dt>
244 <pre class="prettyprint lang-config">RewriteRule "^/produits/vues$" "http://site2.example.com/voirproduits.html" [R]</pre>
246 <p>Ceci informe le client qu'il doit effectuer une nouvelle requête vers
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>
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>
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>
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> :
275 <pre class="prettyprint lang-config">RewriteRule "^puppy.html" "petitchien.html" [NC]</pre>
278 <p>Pour une liste des drapeaux disponibles, leurs significations, et des
279 exemples, voir le document <a href="flags.html">Drapeaux de
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>
294 <img src="../images/syntax_rewritecond.png" alt="Syntaxe de la directive RewriteCond" /><br />
295 <dfn>Figure 3 :</dfn> Syntaxe de la directive RewriteCond
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
302 <pre class="prettyprint lang-config">RewriteCond "%{REMOTE_ADDR}" "^10\.2\."
303 RewriteRule "(.*)" "http://intranet.example.com$1"</pre>
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>
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>
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>
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>
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>
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>
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"><Directory></a></code>) ou dans une section <code class="directive"><a href="../mod/core.html#virtualhost"><VirtualHost></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"><Directory></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>
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>
363 <div class="bottomlang">
364 <p><span>Langues Disponibles: </span><a href="../en/rewrite/intro.html" hreflang="en" rel="alternate" title="English"> en </a> |
365 <a href="../fr/rewrite/intro.html" title="Français"> fr </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&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';
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';
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);
380 d.write('<div id="comments_thread">Comments are disabled for this page at the moment.<\/div>');
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') {