mirror of
				https://github.com/apache/httpd.git
				synced 2025-11-03 17:53:20 +03:00 
			
		
		
		
	git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1742727 13f79535-47bb-0310-9956-ffa450edef68
		
			
				
	
	
		
			215 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			215 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
<?xml version="1.0" encoding="UTF-8" ?>
 | 
						|
<!DOCTYPE manualpage SYSTEM "./style/manualpage.dtd">
 | 
						|
<?xml-stylesheet type="text/xsl" href="./style/manual.fr.xsl"?>
 | 
						|
<!-- English Revision : 1741842 -->
 | 
						|
<!-- 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 !"
 | 
						|
ErrorDocument 500 /cgi-bin/crash-recover
 | 
						|
ErrorDocument 500 http://error.example.com/server_error.html
 | 
						|
ErrorDocument 404 /errors/not_found.html 
 | 
						|
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>
 | 
						|
 | 
						|
      <highlight language="perl">
 | 
						|
...
 | 
						|
print  "Content-type: text/html\n"; 
 | 
						|
printf "Status: %s Condition Intercepted\n", $ENV{"REDIRECT_STATUS"}; 
 | 
						|
...
 | 
						|
      </highlight>
 | 
						|
 | 
						|
      <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>
 | 
						|
 | 
						|
    <highlight language="config">
 | 
						|
    # Multi-language error messages
 | 
						|
    #Include conf/extra/httpd-multilang-errordoc.conf
 | 
						|
    </highlight>
 | 
						|
 | 
						|
    <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>
 |