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
8 <title>mod_dir - 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">
15 <link href="../images/favicon.ico" rel="shortcut icon" /></head>
17 <div id="page-header">
18 <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>
19 <p class="apache">Serveur Apache HTTP Version 2.5</p>
20 <img alt="" src="../images/feather.gif" /></div>
21 <div class="up"><a href="./"><img title="<-" alt="<-" src="../images/left.gif" /></a></div>
23 <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.5</a> > <a href="./">Modules</a></div>
24 <div id="page-content">
25 <div id="preamble"><h1>Module Apache mod_dir</h1>
27 <p><span>Langues Disponibles: </span><a href="../en/mod/mod_dir.html" hreflang="en" rel="alternate" title="English"> en </a> |
28 <a href="../fr/mod/mod_dir.html" title="Français"> fr </a> |
29 <a href="../ja/mod/mod_dir.html" hreflang="ja" rel="alternate" title="Japanese"> ja </a> |
30 <a href="../ko/mod/mod_dir.html" hreflang="ko" rel="alternate" title="Korean"> ko </a> |
31 <a href="../tr/mod/mod_dir.html" hreflang="tr" rel="alternate" title="Türkçe"> tr </a></p>
33 <table class="module"><tr><th><a href="module-dict.html#Description">Description:</a></th><td>Permet la redirection des adresses se terminant par un
34 répertoire sans slash de fin et la mise à disposition des fichiers index
35 de répertoire</td></tr>
36 <tr><th><a href="module-dict.html#Status">Statut:</a></th><td>Base</td></tr>
37 <tr><th><a href="module-dict.html#ModuleIdentifier">Identificateur de Module:</a></th><td>dir_module</td></tr>
38 <tr><th><a href="module-dict.html#SourceFile">Fichier Source:</a></th><td>mod_dir.c</td></tr></table>
41 <p>L'index d'un répertoire peut provenir de deux sources :</p>
44 <li>Un fichier écrit par l'utilisateur, dont le nom, en général
45 appelé <code>index.html</code>, peut être défini à l'aide de la
46 directive <code class="directive"><a href="#directoryindex">DirectoryIndex</a></code>
47 fournie par le module <code class="module"><a href="../mod/mod_dir.html">mod_dir</a></code>.</li>
49 <li>Un listing généré par le serveur, par l'intermédiaire du
50 module <code class="module"><a href="../mod/mod_autoindex.html">mod_autoindex</a></code>.</li>
52 <p>Les deux fonctions sont bien distinctes, si bien que vous pouvez
53 supprimer (ou remplacer) la génération automatique d'index, si vous
56 <p>Une redirection "slash de fin" est effectuée lorsque le serveur
57 reçoit une requête pour une URL du style
58 <code>http://nom-serveur/foo/nom-rep</code> où <code>nom-rep</code>
59 est le nom d'un répertoire. Comme les répertoires nécessitent un slash de
60 fin, <code class="module"><a href="../mod/mod_dir.html">mod_dir</a></code> effectue une redirection vers
61 <code>http://nom-serveur/foo/nom-rep/</code>.</p>
63 <div id="quickview"><h3 class="directives">Directives</h3>
65 <li><img alt="" src="../images/down.gif" /> <a href="#directoryindex">DirectoryIndex</a></li>
66 <li><img alt="" src="../images/down.gif" /> <a href="#directoryindexredirect">DirectoryIndexRedirect</a></li>
67 <li><img alt="" src="../images/down.gif" /> <a href="#directoryslash">DirectorySlash</a></li>
68 <li><img alt="" src="../images/down.gif" /> <a href="#fallbackresource">FallbackResource</a></li>
70 <ul class="seealso"><li><a href="#comments_section">Commentaires</a></li></ul></div>
72 <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
73 <div class="directive-section"><h2><a name="DirectoryIndex" id="DirectoryIndex">DirectoryIndex</a> <a name="directoryindex" id="directoryindex">Directive</a></h2>
74 <table class="directive">
75 <tr><th><a href="directive-dict.html#Description">Description:</a></th><td>Liste des fichiers ressources à rechercher lorsque le
76 client envoie une requête pour un répertoire</td></tr>
77 <tr><th><a href="directive-dict.html#Syntax">Syntaxe:</a></th><td><code>DirectoryIndex
78 disabled | <var>url locale</var> [<var>url locale</var>] ...</code></td></tr>
79 <tr><th><a href="directive-dict.html#Default">Défaut:</a></th><td><code>DirectoryIndex index.html</code></td></tr>
80 <tr><th><a href="directive-dict.html#Context">Contexte:</a></th><td>configuration du serveur, serveur virtuel, répertoire, .htaccess</td></tr>
81 <tr><th><a href="directive-dict.html#Override">AllowOverride:</a></th><td>Indexes</td></tr>
82 <tr><th><a href="directive-dict.html#Status">Statut:</a></th><td>Base</td></tr>
83 <tr><th><a href="directive-dict.html#Module">Module:</a></th><td>mod_dir</td></tr>
85 <p>La directive <code class="directive">DirectoryIndex</code> permet de
86 définir une liste de fichiers ressources à rechercher lorsqu'un
87 client envoie une requête pour l'index d'un répertoire, en ajoutant
88 un '/' à la fin du nom de ce dernier. <var>url locale</var> est
89 l'URL (codée avec caractères '%') d'un document du serveur, relative
90 au répertoire faisant l'objet de la requête ; il s'agit en général
91 du nom d'un fichier situé dans le répertoire. Si plusieurs URLs sont
92 fournies, le serveur renverra la première d'entre elles qui
93 correspond à une ressource existante. Si aucune ressource ne
94 correspond à la liste des URLs spécifiées, et si l'option
95 <code>Indexes</code> est définie, le serveur générera son propre
96 listing du répertoire.</p>
98 <div class="example"><h3>Exemple</h3><pre class="prettyprint lang-config">
99 DirectoryIndex index.html
103 <p>Avec cette configuration, une requête pour l'URL
104 <code>http://example.com/docs/</code> renverrait au client la
105 ressource <code>http://example.com/docs/index.html</code> si elle
106 existe, ou provoquerait la génération du listing du répertoire si la
107 ressource n'existe pas.</p>
109 <p>Notez qu'il n'est pas nécessaire que les documents soient
110 relatifs au répertoire ;</p>
112 <pre class="prettyprint lang-config">
113 DirectoryIndex index.html index.txt /cgi-bin/index.pl
117 <p>provoquerait l'exécution du script CGI
118 <code>/cgi-bin/index.pl</code> si aucun des fichiers
119 <code>index.html</code> ou <code>index.txt</code> n'existe dans le
120 répertoire considéré.</p>
122 <p>La spécification du seul argument "disabled" empêche
123 <code class="module"><a href="../mod/mod_dir.html">mod_dir</a></code> de rechercher un index. Un argument
124 "disabled" sera interprété de manière littérale si d'autres
125 arguments sont présents avant ou après lui, même s'ils sont
126 eux-mêmes des arguments "disabled".</p>
128 <p><strong>Note :</strong>La définition de plusieurs directives
129 <code class="directive">DirectoryIndex</code> au sein d'un <a href="../sections.html"><em>même
130 contexte</em></a> permet d'ajouter des ressources à rechercher plutôt
131 que de remplacer celle déjà définies :
133 <pre class="prettyprint lang-config">
134 # Exemple A: définit index.html comme page d'index, ainsi qu'index.php.
135 <Directory /foo>
136 DirectoryIndex index.html
137 DirectoryIndex index.php
140 # Exemple B: identique à l'exemple A, mais avec une seule directive.
141 <Directory /foo>
142 DirectoryIndex index.html index.php
145 # Exemple C: pour remplacer la liste des pages d'index par une autre,
146 # vous devez tout d'abord supprimer la première liste : dans l'exemple
147 # suivant, il ne restera qu'index.php comme page d'index.
148 <Directory /foo>
149 DirectoryIndex index.html
150 DirectoryIndex disabled
151 DirectoryIndex index.php
158 <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
159 <div class="directive-section"><h2><a name="DirectoryIndexRedirect" id="DirectoryIndexRedirect">DirectoryIndexRedirect</a> <a name="directoryindexredirect" id="directoryindexredirect">Directive</a></h2>
160 <table class="directive">
161 <tr><th><a href="directive-dict.html#Description">Description:</a></th><td>Définit une redirection externe pour les index de
164 <tr><th><a href="directive-dict.html#Syntax">Syntaxe:</a></th><td><code>DirectoryIndexRedirect on | off | permanent | temp | seeother |
167 <tr><th><a href="directive-dict.html#Default">Défaut:</a></th><td><code>DirectoryIndexRedirect off</code></td></tr>
168 <tr><th><a href="directive-dict.html#Context">Contexte:</a></th><td>configuration du serveur, serveur virtuel, répertoire, .htaccess</td></tr>
169 <tr><th><a href="directive-dict.html#Override">AllowOverride:</a></th><td>Indexes</td></tr>
170 <tr><th><a href="directive-dict.html#Status">Statut:</a></th><td>Base</td></tr>
171 <tr><th><a href="directive-dict.html#Module">Module:</a></th><td>mod_dir</td></tr>
172 <tr><th><a href="directive-dict.html#Compatibility">Compatibilité:</a></th><td>Disponible depuis la version 2.3.14</td></tr>
174 <p>Par défaut, c'est la page définie par la directive
175 <code class="directive">DirectoryIndex</code> qui est sélectionnée et
176 renvoyée de manière transparente au client. La directive
177 <code class="directive">DirectoryIndexRedirect</code> permet de rediriger le
178 client via une redirection de type 3xx.</p>
180 <p>Les arguments acceptés sont :</p>
182 <li><code>on</code> : envoie une redirection 302 vers l'index choisi.</li>
183 <li><code>off</code> : n'envoie aucune redirection. Il s'agit du comportement historique de mod_dir.</li>
184 <li><code>permanent</code> : envoie une redirection 301 (permanent) vers l'index choisi.</li>
185 <li><code>temp</code> : ceci est équivalent à <code>on</code></li>
186 <li><code>seeother</code> : envoie une redirection 303 (également appelée "See Other") vers l'index choisi.</li>
187 <li><var>3xx-code</var> : envoie une redirection accompagnée du code 3xx choisi.</li>
192 <div class="example"><h3>Exemple</h3><pre class="prettyprint lang-config">
193 DirectoryIndexRedirect on
197 <p>Une requête pour <code>http://example.com/docs/</code> se
198 solderait par une redirection temporaire vers
199 <code>http://example.com/docs/index.html</code> si cette ressource
204 <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
205 <div class="directive-section"><h2><a name="DirectorySlash" id="DirectorySlash">DirectorySlash</a> <a name="directoryslash" id="directoryslash">Directive</a></h2>
206 <table class="directive">
207 <tr><th><a href="directive-dict.html#Description">Description:</a></th><td>Activation/Désactivation de la redirection "slash de
209 <tr><th><a href="directive-dict.html#Syntax">Syntaxe:</a></th><td><code>DirectorySlash On|Off</code></td></tr>
210 <tr><th><a href="directive-dict.html#Default">Défaut:</a></th><td><code>DirectorySlash On</code></td></tr>
211 <tr><th><a href="directive-dict.html#Context">Contexte:</a></th><td>configuration du serveur, serveur virtuel, répertoire, .htaccess</td></tr>
212 <tr><th><a href="directive-dict.html#Override">AllowOverride:</a></th><td>Indexes</td></tr>
213 <tr><th><a href="directive-dict.html#Status">Statut:</a></th><td>Base</td></tr>
214 <tr><th><a href="directive-dict.html#Module">Module:</a></th><td>mod_dir</td></tr>
216 <p>La directive <code class="directive">DirectorySlash</code> permet de
217 déterminer si <code class="module"><a href="../mod/mod_dir.html">mod_dir</a></code> doit corriger ou non les URLs
218 pointant vers un répertoire.</p>
220 <p>En général, si un utilisateur envoie une requête pour une
221 ressource sans slash de fin, cette ressource représentant un
222 répertoire, <code class="module"><a href="../mod/mod_dir.html">mod_dir</a></code> le redirige vers la même
223 ressource, mais <em>en ajoutant</em> un slash de fin, et ceci pour
224 plusieurs bonnes raisons :</p>
227 <li>La requête de l'utilisateur contiendra finalement l'URL
228 canonique de la ressource</li>
229 <li><code class="module"><a href="../mod/mod_autoindex.html">mod_autoindex</a></code> fonctionnera correctement. Comme
230 il n'indique pas le chemin dans le lien, le chemin de l'URL serait
232 <li>La directive <code class="directive"><a href="#directoryindex">DirectoryIndex</a></code> n'est évaluée
233 <em>que</em> pour les répertoires se terminant par un slash.</li>
234 <li>Les références à des URLs relatives dans les pages html
235 fonctionneront alors correctement.</li>
238 <p>Si vous ne souhaitez pas voir ces effets, <em>et</em> si
239 les raisons évoquées ci-dessus ne s'appliquent pas à vous, vous
240 pouvez désactiver la redirection comme indiqué ci-dessous.
241 Gardez cependant à l'esprit que ceci peut avoir des répercutions en
242 matière de sécurité.</p>
244 <pre class="prettyprint lang-config">
245 # voir l'avertissement de sécurité ci-dessous !
246 <Location /some/path>
248 SetHandler some-handler
253 <div class="warning"><h3>Avertissement de sécurité</h3>
254 <p>La désactivation de la redirection "slash de fin" peut entraîner
255 la divulgation d'informations. Considérons la situation où
256 <code class="module"><a href="../mod/mod_autoindex.html">mod_autoindex</a></code> est actif (<code>Options
257 +Indexes</code>), où la directive <code class="directive"><a href="#directoryindex">DirectoryIndex</a></code> a pour valeur une ressource valide (par
258 exemple <code>index.html</code>), et où aucun gestionnaire
259 particulier n'a été défini pour cette URL. Dans ce cas, une requête
260 avec slash de fin afficherait le contenu du fichier
261 <code>index.html</code> ; <strong>par contre, une requête sans slash
262 de fin afficherait un listing du contenu du
263 répertoire</strong>.</p>
265 <p>Notez aussi que certains navigateurs peuvent modifier par erreur
266 des requêtes POST en requêtes GET lors d'une redirection, les
267 données POST étant alors perdues.</p>
270 <div class="top"><a href="#page-header"><img alt="top" src="../images/up.gif" /></a></div>
271 <div class="directive-section"><h2><a name="FallbackResource" id="FallbackResource">FallbackResource</a> <a name="fallbackresource" id="fallbackresource">Directive</a></h2>
272 <table class="directive">
273 <tr><th><a href="directive-dict.html#Description">Description:</a></th><td>Définit une URL par défaut pour les requêtes qui ne ciblent
274 aucun fichier</td></tr>
275 <tr><th><a href="directive-dict.html#Syntax">Syntaxe:</a></th><td><code>FallbackResource disabled | <var>url-locale</var></code></td></tr>
276 <tr><th><a href="directive-dict.html#Default">Défaut:</a></th><td><code>Désactivé - httpd renvoie un code d'erreur 404 (Not Found)</code></td></tr>
277 <tr><th><a href="directive-dict.html#Context">Contexte:</a></th><td>configuration du serveur, serveur virtuel, répertoire, .htaccess</td></tr>
278 <tr><th><a href="directive-dict.html#Override">AllowOverride:</a></th><td>Indexes</td></tr>
279 <tr><th><a href="directive-dict.html#Status">Statut:</a></th><td>Base</td></tr>
280 <tr><th><a href="directive-dict.html#Module">Module:</a></th><td>mod_dir</td></tr>
282 <p>Cette directive permet de définir un traitement pour toute URL
283 qui ne correspond à aucune ressource de votre système de fichiers,
284 et qui provoquerait sans cela l'envoi d'un code d'erreur HTTP 404
287 <pre class="prettyprint lang-config">
288 FallbackResource /not-404.php
291 <p>fait en sorte que les requêtes ne correspondant à aucun fichier
292 soient traitées par <code>non-404.php</code>, sans affecter les
293 requêtes pour des fichiers existants.</p>
294 <p>Il est souvent souhaitable qu'un seul fichier ou ressource traite
295 toutes les requêtes à destination d'un répertoire
296 particulier, sauf pour les requêtes qui correspondent à un fichier
297 ou script existant. On y fait souvent référence sous le terme
298 'contrôleur frontal'.</p>
299 <p>Dans les versions plus anciennes de httpd, cet effet nécessitait
300 en général <code class="module"><a href="../mod/mod_rewrite.html">mod_rewrite</a></code>, et l'utilisation des tests
301 conditionnels <code>-f</code> et <code>-d</code> pour vérifier
302 l'existence des fichiers et répertoires. Maintenant, une seule ligne
303 de configuration est nécessaire.</p>
304 <pre class="prettyprint lang-config">
305 FallbackResource /index.php
308 <p>Les fichiers existants comme des images, des fichiers css, etc...
309 seront traités normalement.</p>
310 <p>Utilisez l'argument <code>disabled</code> pour désactiver cette
311 fonctionnalité si l'héritage d'un répertoire parent n'est pas
313 <p>Pour un URI intermédiaire tel que
314 <em>http://example.com/blog/</em>, cet URI intermédiaire doit être
315 spécifié en tant que <var>url-locale</var> :</p>
316 <pre class="prettyprint lang-config">
317 <Directory /web/example.com/htdocs/blog>
318 FallbackResource /blog/index.php
320 <Directory /web/example.com/htdocs/blog/images>
321 FallbackResource disabled
328 <div class="bottomlang">
329 <p><span>Langues Disponibles: </span><a href="../en/mod/mod_dir.html" hreflang="en" rel="alternate" title="English"> en </a> |
330 <a href="../fr/mod/mod_dir.html" title="Français"> fr </a> |
331 <a href="../ja/mod/mod_dir.html" hreflang="ja" rel="alternate" title="Japanese"> ja </a> |
332 <a href="../ko/mod/mod_dir.html" hreflang="ko" rel="alternate" title="Korean"> ko </a> |
333 <a href="../tr/mod/mod_dir.html" hreflang="tr" rel="alternate" title="Türkçe"> tr </a></p>
334 </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>
335 <script type="text/javascript"><!--//--><![CDATA[//><!--
336 var comments_shortname = 'httpd';
337 var comments_identifier = 'http://httpd.apache.org/docs/trunk/mod/mod_dir.html';
339 if (w.location.hostname.toLowerCase() == "httpd.apache.org") {
340 d.write('<div id="comments_thread"><\/div>');
341 var s = d.createElement('script');
342 s.type = 'text/javascript';
344 s.src = 'https://comments.apache.org/show_comments.lua?site=' + comments_shortname + '&page=' + comments_identifier;
345 (d.getElementsByTagName('head')[0] || d.getElementsByTagName('body')[0]).appendChild(s);
348 d.write('<div id="comments_thread">Comments are disabled for this page at the moment.<\/div>');
350 })(window, document);
351 //--><!]]></script></div><div id="footer">
352 <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>
353 <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[//><!--
354 if (typeof(prettyPrint) !== 'undefined') {