mirror of
				https://github.com/apache/httpd.git
				synced 2025-10-31 19:10:37 +03:00 
			
		
		
		
	git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1340491 13f79535-47bb-0310-9956-ffa450edef68
		
			
				
	
	
		
			215 lines
		
	
	
		
			9.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			215 lines
		
	
	
		
			9.8 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| <?xml version="1.0" encoding="ISO-8859-1" ?>
 | |
| <!DOCTYPE manualpage SYSTEM "./style/manualpage.dtd">
 | |
| <?xml-stylesheet type="text/xsl" href="./style/manual.fr.xsl"?>
 | |
| <!-- English Revision : 1330883 -->
 | |
| <!-- French translation : Lucien GENTIS -->
 | |
| <!-- Reviewed by : Vincent Deffontaines -->
 | |
| 
 | |
| <!--
 | |
|  Licensed to the Apache Software Foundation (ASF) under one or more
 | |
|  contributor license agreements.  See the NOTICE file distributed with
 | |
|  this work for additional information regarding copyright ownership.
 | |
|  The ASF licenses this file to You under the Apache License, Version 2.0
 | |
|  (the "License"); you may not use this file except in compliance with
 | |
|  the License.  You may obtain a copy of the License at
 | |
| 
 | |
|      http://www.apache.org/licenses/LICENSE-2.0
 | |
| 
 | |
|  Unless required by applicable law or agreed to in writing, software
 | |
|  distributed under the License is distributed on an "AS IS" BASIS,
 | |
|  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
|  See the License for the specific language governing permissions and
 | |
|  limitations under the License.
 | |
| -->
 | |
| 
 | |
| <manualpage metafile="custom-error.xml.meta">
 | |
| 
 | |
|   <title>Messages d'erreur personnalisés</title>
 | |
| 
 | |
|   <summary>
 | |
|     <p>Le serveur HTTP Apache fournit des messages d'erreur génériques
 | |
|     pour les codes de statut 4xx ou 5xx ; ces messages sont cependant
 | |
|     relativement austères, imprécis, et peuvent s'avérer intimidants
 | |
|     pour les visiteurs du site. Si vous le souhaitez, vous pouvez
 | |
|     afficher des messages d'erreur plus conviviaux, dans un langage
 | |
|     autre que l'anglais, ou même sous une forme plus en adéquation avec
 | |
|     le style de votre site.</p>
 | |
| 
 | |
|     <p>Il est possible de définir des messages d'erreur personnalisés
 | |
|     pour chaque code de statut HTTP associé à une condition d'erreur -
 | |
|     c'est à dire tout code de statut 4xx ou 5xx.</p>
 | |
| 
 | |
|     <p>De plus, il est possible de
 | |
|     personnaliser le message d'erreur en fonction d'un jeu de valeurs
 | |
|     fourni, en utilisant les <a href="howto/ssi.html">Inclusions Côté
 | |
|     Serveur (SSI)</a>. Un programme CGI ou un autre gestionnaire
 | |
|     dynamique (PHP, mod_perl, etc...) peut aussi utiliser ces variables
 | |
|     pour gérer les conditions d'erreur.</p>
 | |
| 
 | |
| 
 | |
|   </summary>
 | |
| 
 | |
|   <section id="configuration"><title>Configuration</title>
 | |
| 
 | |
|     <p>Les messages d'erreur personnalisés sont configurés via la
 | |
|     directive <directive module="core">ErrorDocument</directive>, qui
 | |
|     peut être utilisée dans un contexte global, serveur virtuel ou
 | |
|     répertoire. On peut utiliser cette directive dans les fichiers
 | |
|     .htaccess si <directive module="core">AllowOverride</directive> est
 | |
|     définie à FileInfo.</p>
 | |
| 
 | |
|     <highlight language="config">
 | |
| ErrorDocument 500 "Désolé, notre script s'est
 | |
| crashé ; comme c'est dommage !"<br />
 | |
| ErrorDocument 500 /cgi-bin/crash-recover<br />
 | |
| ErrorDocument 500 http://error.example.com/server_error.html<br />
 | |
| ErrorDocument 404 /errors/not_found.html <br />
 | |
| ErrorDocument 401 /subscription/how_to_subscribe.html
 | |
|     </highlight>
 | |
| 
 | |
| <p>La syntaxe de la directive <code>ErrorDocument</code> est :</p>
 | |
|       <highlight language="config">
 | |
|       ErrorDocument <code_3_chiffres> <action>
 | |
|     </highlight>
 | |
|       <p>où action peut être traitée comme :</p>
 | |
|         <ol>
 | |
|       <li>Une URL de redirection local (si l'action commence par un "/").</li>
 | |
|       <li>Une URL de redirection externe (si action est une URL valide).</li>
 | |
|       <li>Le texte à afficher (si l'action ne répond à aucune des
 | |
|       deux conditions précédentes). Entourez le texte de guillemets (")
 | |
|       s'il contient plusieurs mots.</li>
 | |
|         </ol>
 | |
| 
 | |
|     <p>Dans le cas d'une redirection vers une URL locale, des variables
 | |
|     d'environnement supplémentaires sont définies de façon à ce que la
 | |
|     réponse puisse être personnalisée par la suite. Elles ne sont pas
 | |
|     envoyées aux URLs externes.</p>
 | |
| 
 | |
|   </section>
 | |
| 
 | |
|         <section id="variables"><title>Variables disponibles</title>
 | |
| 
 | |
|       <p>La redirection vers une autre URL peut être utile, mais
 | |
|       seulement s'il est possible de transmettre certaines informations
 | |
|       qui pourront être utilisées pour expliquer ou journaliser
 | |
|       la condition d'erreur ou le problème plus clairement.</p>
 | |
| 
 | |
| 	<p>Pour y parvenir, lorsque la redirection d'erreur est envoyée,
 | |
| 	des variables d'environnement supplémentaires sont définies à
 | |
| 	partir des en-têtes de la requête originale en préfixant le nom
 | |
| 	d'origine de l'en-tête par 'REDIRECT_', ce qui permet de fournir au
 | |
| 	message d'erreur le contexte de la requête originelle.</p>
 | |
| 
 | |
|       <p>Par exemple, en plus des variables d'environnement habituelles,
 | |
|       vous pouvez recevoir ce qui suit :</p>
 | |
| 
 | |
| 
 | |
|       <example>
 | |
|         REDIRECT_HTTP_ACCEPT=*/*, image/gif, image/jpeg, image/png<br />
 | |
|         REDIRECT_HTTP_USER_AGENT=Mozilla/5.0 Fedora/3.5.8-1.fc12 Firefox/3.5.8<br />
 | |
|         REDIRECT_PATH=.:/bin:/usr/local/bin:/sbin<br />
 | |
|         REDIRECT_QUERY_STRING=<br />
 | |
|         REDIRECT_REMOTE_ADDR=121.345.78.123<br />
 | |
|         REDIRECT_REMOTE_HOST=client.example.com<br />
 | |
|         REDIRECT_SERVER_NAME=www.example.edu<br />
 | |
|         REDIRECT_SERVER_PORT=80<br />
 | |
|         REDIRECT_SERVER_SOFTWARE=Apache/2.2.15<br />
 | |
|         REDIRECT_URL=/cgi-bin/buggy.pl
 | |
|       </example>
 | |
| 
 | |
|       <p>Les variables d'environnement <code>REDIRECT_</code> sont
 | |
|       créées à partir des variables d'environnement préexistantes à la
 | |
|       redirection qui sont préfixées par la chaîne <code>REDIRECT_</code> ;
 | |
|       par exemple, <code>HTTP_USER_AGENT</code> devient
 | |
|       <code>REDIRECT_HTTP_USER_AGENT</code>.</p>
 | |
| 
 | |
|       <p><code>REDIRECT_URL</code>, <code>REDIRECT_STATUS</code>, et
 | |
|       <code>REDIRECT_QUERY_STRING</code> sont systématiquement définies,
 | |
|       les autres variables n'étant définies que si l'en-tête
 | |
|       correspondant existait avant la condition d'erreur.</p>
 | |
| 
 | |
|       <p><strong>Aucune</strong> d'entre elles ne sera définie si votre
 | |
|       directive <directive module="core">ErrorDocument</directive>
 | |
|       spécifie une redirection <em>externe</em> (toute URL commençant
 | |
|       par un protocole du style <code>http:</code>, même si elle fait
 | |
|       référence au même hôte que le serveur).</p>
 | |
| 
 | |
|   </section>
 | |
| 
 | |
|   <section id="custom"><title>Personnalisation des messages d'erreur</title>
 | |
| 
 | |
| 
 | |
| 	<p>Si vous faites pointer votre directive
 | |
| 	<code>ErrorDocument</code> vers certains gestionnaires
 | |
| 	dynamiques comme les inclusions côté serveur, les scripts CGI ou
 | |
| 	d'autres gestionnaires, vous pouvez utiliser les variables
 | |
| 	d'environnement supplémentaires disponibles pour personnaliser
 | |
| 	le message.</p>
 | |
| 
 | |
| 
 | |
|       <p>Si la directive ErrorDname-basedocument spécifie une redirection locale
 | |
|       vers un script CGI, ce dernier doit ajouter un en-tête
 | |
|       "<code>Status:</code>" dans sa sortie afin de s'assurer du bon
 | |
|       acheminement jusqu'au client de la condition d'erreur qui a
 | |
|       provoqué cette redirection. Par exemple, un script Perl spécifié
 | |
|       par une directive ErrorDocument pourrait contenir ce qui suit
 | |
|       :</p>
 | |
| 
 | |
|       <example>
 | |
|         ... <br />
 | |
|         print  "Content-type: text/html\n"; <br />
 | |
|         printf "Status: %s Condition Intercepted\n", $ENV{"REDIRECT_STATUS"}; <br />
 | |
|         ...
 | |
|       </example>
 | |
| 
 | |
|       <p>Si un script est dédié à la gestion d'une condition d'erreur
 | |
|       spécifique, telle que <code>404 Not Found</code>, il
 | |
|       peut utiliser le code et le texte de l'erreur spécifiques à la
 | |
|       place.</p>
 | |
| 
 | |
|       <p>Notez que si la réponse contient un en-tête
 | |
|       <code>Location:</code> (afin d'initier une redirection côté
 | |
|       client), le script <em>doit</em> émettre un en-tête approprié
 | |
|       (comme <code>302 Found</code>). Dans le cas contraire,
 | |
|       l'en-tête <code>Location:</code> ne produira aucun effet.</p>
 | |
|   </section>
 | |
| 
 | |
|   <section id="multi-lang"><title>Messages d'erreur personnalisés
 | |
|   multilingues</title>
 | |
| 
 | |
|     <p>Vous trouverez dans la distribution du serveur HTTP Apache un
 | |
|     répertoire contenant des messages d'erreur personnalisés traduits en
 | |
|     16 langues différentes. Pour activer cette fonctionnalité, vous
 | |
|     pouvez aussi inclure un fichier de configuration qui se trouve dans
 | |
|     le répertoire de configuration <code>conf/extra</code>.</p>
 | |
| 
 | |
|     <p>Dans le fichier de configuration de votre serveur, vous trouverez
 | |
|     un groupe de lignes du style :</p>
 | |
| 
 | |
|     <example>
 | |
|     # Multi-language error messages<br />
 | |
|     #Include conf/extra/httpd-multilang-errordoc.conf
 | |
|     </example>
 | |
| 
 | |
|     <p>Décommentez la ligne <code>Include</code> pour activer cette
 | |
|     fonctionnalité, et présenter des messages d'erreur dont le langage
 | |
|     sera négocié en fonction du langage préféré défini au niveau du
 | |
|     navigateur du client.</p>
 | |
| 
 | |
|     <p>De plus, ces documents contiennent diverses variables
 | |
|     <code>REDIRECT_</code>, de façon à ce que l'utilisateur final
 | |
|     dispose d'informations supplémentaires à propos de ce qui a pu se
 | |
|     produire, et de ce qu'il est susceptible de faire maintenant.</p>
 | |
| 
 | |
|     <p>Ces documents peuvent être personnalisés en fournissant autant
 | |
|     d'informations utiles que vous le souhaitez aux utilisateurs à
 | |
|     propos de votre site, et de ce qu'ils sont susceptibles d'y trouver.</p>
 | |
| 
 | |
|     <p>Pour pouvoir utiliser cette fonctionnalité, vous devez activer
 | |
|     <module>mod_include</module> et <module>mod_negotiation</module>.</p>
 | |
| 
 | |
|  </section>
 | |
| 
 | |
| 
 | |
| </manualpage>
 |