<-
Apache > Serveur HTTP > Documentation > Version 2.2 > Modules

Fonctionalit�s de Base Apache

Langues Disponibles:  de  |  en  |  fr  |  ja  |  tr 

Cette traduction peut �tre p�rim�e. V�rifiez la version anglaise pour les changements r�cents.
Description:Fonctionnalit�s de base du serveur HTTP Apache disponibles en toutes circonstances
Statut:Core

Directives

top

AcceptFilter Directive

Description:Permet d'optimiser la configuration d'un socket pour l'�coute d'un protocole
Syntaxe:AcceptFilter protocole filtre d'acceptation
Contexte:configuration du serveur
Statut:Core
Module:core
Compatibilit�:Disponible avec Apache version 2.1.5 et sup�rieures

Cette directive permet d'effectuer une optimisation du socket d'�coute d'un type de protocole en fonction du syst�me d'exploitation. Le but premier est de faire en sorte que le noyau n'envoie pas de socket au processus du serveur jusqu'� ce que des donn�es soient re�ues, ou qu'une requ�te HTTP compl�te soit mise en tampon. Seuls les Filtres d'acceptation de FreeBSD et le filtre plus primitif TCP_DEFER_ACCEPT sous Linux sont actuellement support�s.

Sous FreeBSD, les valeurs par d�faut sont :

AcceptFilter http httpready
AcceptFilter https dataready

Le filtre d'acceptation httpready met en tampon des requ�tes HTTP enti�res au niveau du noyau. Quand une requ�te enti�re a �t� re�ue, le noyau l'envoie au serveur. Voir la page de manuel de accf_http(9) pour plus de d�tails. Comme les requ�tes HTTPS sont chiffr�es, celles-ci n'autorisent que le filtre accf_data(9).

Sous Linux, les valeurs par d�faut sont :

AcceptFilter http data
AcceptFilter https data

Le filtre TCP_DEFER_ACCEPT de Linux ne supporte pas la mise en tampon des requ�tes http. Toute valeur autre que none active le filtre TCP_DEFER_ACCEPT pour ce protocole. Pour plus de d�tails, voir la page de manuel Linux de tcp(7).

L'utilisation de la valeur none comme argument d�sactive tout filtre d'acceptation pour ce protocole. Elle peut �tre utile dans le cas d'un protocole pour lequel un serveur doit d'abord envoyer des donn�es, comme nntp :

AcceptFilter nntp none

Voir aussi

top

AcceptPathInfo Directive

Description:Les ressources acceptent des informations sous forme d'un nom de chemin en fin de requ�te.
Syntaxe:AcceptPathInfo On|Off|Default
D�faut:AcceptPathInfo Default
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core
Compatibilit�:Disponible avec Apache version 2.0.30 et sup�rieures

Cette directive permet de d�finir si les requ�tes contenant des informations sous forme d'un nom de chemin suivant le nom d'un fichier r�el (ou un fichier qui n'existe pas dans un r�pertoire qui existe) doivent �tre accept�es ou rejet�es. Les scripts peuvent acc�der � cette information via la variable d'environnement PATH_INFO.

Supposons par exemple que /test/ pointe vers un r�pertoire qui ne contient que le fichier here.html. Les requ�tes pour /test/here.html/more et /test/nothere.html/more vont affecter la valeur /more � la variable d'environnement PATH_INFO.

L'argument de la directive AcceptPathInfo poss�de trois valeurs possibles :

Off
Une requ�te ne sera accept�e que si elle correspond � un chemin qui existe. Par cons�quent, une requ�te contenant une information de chemin apr�s le nom de fichier r�el comme /test/here.html/more dans l'exemple ci-dessus renverra une erreur "404 NOT FOUND".
On
Une requ�te sera accept�e si la partie principale du chemin correspond � un fichier existant. Dans l'exemple ci-dessus /test/here.html/more, la requ�te sera accept�e si /test/here.html correspond � un nom de fichier valide.
Default
Le traitement des requ�tes est d�termin� par le gestionnaire responsable de la requ�te. Le gestionnaire de base pour les fichiers normaux rejette par d�faut les requ�tes avec PATH_INFO. Les gestionnaires qui servent des scripts, comme cgi-script et isapi-handler, acceptent en g�n�ral par d�faut les requ�tes avec PATH_INFO.

Le but premier de la directive AcceptPathInfo est de vous permettre de remplacer le choix du gestionnaire d'accepter ou de rejeter PATH_INFO. Ce remplacement est n�cessaire par exemple, lorsque vous utilisez un filtre, comme INCLUDES, pour g�n�rer un contenu bas� sur PATH_INFO. Le gestionnaire de base va en g�n�ral rejeter la requ�te, et vous pouvez utiliser la configuration suivante pour utiliser un tel script :

<Files "mes-chemins.shtml">
Options +Includes
SetOutputFilter INCLUDES
AcceptPathInfo On
</Files>

top

AccessFileName Directive

Description:Nom du fichier de configuration distribu�
Syntaxe:AccessFileName nom-du-fichier [nom-du-fichier] ...
D�faut:AccessFileName .htaccess
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

Au cours du traitement d'une requ�te, le serveur recherche le premier fichier de configuration existant � partir de la liste de noms dans chaque r�pertoire composant le chemin du document, � partir du moment o� les fichiers de configuration distribu�s sont activ�s pour ce r�pertoire. Par exemple :

AccessFileName .acl

avant de renvoyer le document /usr/local/web/index.html, le serveur va rechercher les fichiers /.acl, /usr/.acl, /usr/local/.acl et /usr/local/web/.acl pour y lire d'�ventuelles directives, � moins quelles n'aient �t� d�sactiv�es avec

<Directory />
AllowOverride None
</Directory>

Voir aussi

top

AddDefaultCharset Directive

Description:Param�tre jeu de caract�res par d�faut � ajouter quand le type de contenu d'une r�ponse est text/plain ou text/html
Syntaxe:AddDefaultCharset On|Off|jeu de caract�res
D�faut:AddDefaultCharset Off
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core

Cette directive sp�cifie une valeur par d�faut pour le param�tre jeu de caract�res du type de m�dia (le nom d'un codage de caract�res) � ajouter � une r�ponse, si et seulement si le type de contenu de la r�ponse est soit text/plain, soit text/html. Ceci va remplacer tout jeu de caract�res sp�cifi� dans le corps de la r�ponse via un �l�ment META, bien que cet effet d�pende en fait souvent de la configuration du client de l'utilisateur. La d�finition de AddDefaultCharset Off d�sactive cette fonctionnalit�. AddDefaultCharset On ajoute un jeu de caract�res par d�faut de iso-8859-1. Toute autre valeur peut �tre d�finie via le param�tre jeu de caract�res, qui doit appartenir � la liste des valeurs de jeux de caract�res enregistr�s par l'IANA � utiliser dans les types de m�dia MIME. Par exemple :

AddDefaultCharset utf-8

La directive AddDefaultCharset ne doit �tre utilis�e que lorsque toutes les ressources textes auxquelles elle s'applique poss�dent le jeu de caract�re sp�cifi�, et qu'il est trop contraignant de d�finir leur jeu de caract�res individuellement. Un exemple de ce type est l'ajout du param�tre jeu de caract�res aux ressources comportant un contenu g�n�r�, comme les scripts CGI h�rit�s qui peuvent �tre vuln�rables � des attaques de type cross-site scripting � cause des donn�es utilisateurs incluses dans leur sortie. Notez cependant qu'une meilleur solution consiste � corriger (ou supprimer) ces scripts, car la d�finition d'un jeu de caract�res par d�faut ne prot�ge pas les utilisateurs qui ont activ� la fonctionnalit� "D�tection automatique de l'encodage des caract�res" dans leur navigateur.

Voir aussi

top

AddOutputFilterByType Directive

Description:assigne un filtre en sortie pour un type MIME particulier
Syntaxe:AddOutputFilterByType filtre[;filtre...] type MIME [type MIME] ...
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core
Compatibilit�:Disponible dans Apache version 2.0.33 et sup�rieures ; obsol�te depuis les versions 2.1

Cette directive active un filtre en sortie particulier pour une requ�te en fonction du type MIME de la r�ponse. Suite � certains probl�mes �voqu�s plus loin, cette directive a �t� abandonn�e. Le m�me r�sultat peut �tre obtenu � l'aide du module mod_filter.

L'exemple suivant active le filtre DEFLATE qui est fourni par le module mod_deflate. Il va compresser toute sortie dont le type MIME est text/html ou text/plain avant de l'envoyer au client.

AddOutputFilterByType DEFLATE text/html text/plain

Si vous voulez assigner plusieurs filtres au contenu, leurs noms doivent �tre s�par�s par des points-virgules. On peut aussi utiliser une directive AddOutputFilterByType pour chacun des filtres � assigner.

La configuration ci-dessous impose le traitement de toute sortie de script dont le type MIME est text/html en premier lieu par le filtre INCLUDES, puis par le filtre DEFLATE.

<Location /cgi-bin/>
Options Includes
AddOutputFilterByType INCLUDES;DEFLATE text/html
</Location>

Note

L'activation de filtres par la directive AddOutputFilterByType peut partiellement �chouer, ou m�me compl�tement dans certains cas. Par exemple, aucun filtre n'est appliqu� si le type MIME n'a pas pu �tre d�termin� et est dans ce cas d�fini par la directive DefaultType, m�me si la directive DefaultType a la m�me valeur.

Cependant, si vous voulez vous assurer que les filtres seront appliqu�s, assignez explicitement le type de contenu � une ressource, par exemple � l'aide d'une directive AddType ou ForceType. Il est aussi recommand� de d�finir le type de contenu dans un script CGI (non-nph).

Voir aussi

top

AllowEncodedSlashes Directive

Description:D�termine si les s�parateurs de chemin encod�s sont autoris�s � transiter dans les URLs tel quel
Syntaxe:AllowEncodedSlashes On|Off|NoDecode
D�faut:AllowEncodedSlashes Off
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core
Compatibilit�:Disponible dans Apache version 2.0.46 et ult�rieures. L'option NoDecode est disponible depuis la version 2.2.18.

La directive AllowEncodedSlashes permet l'utilisation des URLs contenant des s�parateurs de chemin encod�s dans la partie chemin (%2F pour / et m�me %5C pour \ sur les syst�mes concern�s).

Avec la valeur par d�faut, Off, de telles URLs sont refus�es et provoquent le renvoi d'une erreur 404 (Not found).

Avec la valeur On, ces URLs sont accept�es, et les slashes encod�s sont d�cod�s comme tout autre caract�re cod�.

Avec la valeur NoDecode, ces URLs sont accept�es, mais les slashes cod�s ne sont pas d�cod�s et laiss�s dans leur �tat cod�.

D�finir AllowEncodedSlashes � On est surtout utile en association avec PATH_INFO.

Note

Si le codage des slashes dans la partie chemin est n�cessaire, l'utilisation de l'option NoDecode est fortement recommand�e par mesure de s�curit�. Permettre le d�codage des slashes pourrait �ventuellement induire l'autorisation de chemins non s�rs.

Voir aussi

top

AllowOverride Directive

Description:Types de directives autoris�es dans les fichiers .htaccess
Syntaxe:AllowOverride All|None|type directive [type directive] ...
D�faut:AllowOverride All
Contexte:r�pertoire
Statut:Core
Module:core

Lorsque le serveur trouve un fichier .htaccess (dont le nom est d�fini par la directive AccessFileName), il doit savoir lesquelles des directives plac�es dans ce fichier sont autoris�es � modifier la configuration pr�existante.

Valable seulement dans les sections <Directory>

La directive AllowOverride ne peut �tre utilis�e que dans les sections <Directory> d�finies sans expressions rationnelles, et non dans les sections <Location>, <DirectoryMatch> ou <Files>.

Lorsque cette directive est d�finie � None, les fichiers .htaccess sont totalement ignor�s. Dans ce cas, le serveur n'essaiera m�me pas de lire les fichiers .htaccess du syst�me de fichiers.

Lorsque cette directive est d�finie � All, toute directive valable dans le Contexte .htaccess sera autoris�e dans les fichiers .htaccess.

L'argument type directive peut contenir les groupements de directives suivants :

AuthConfig
Permet l'utilisation des directives d'autorisation (AuthDBMGroupFile, AuthDBMUserFile, AuthGroupFile, AuthName, AuthType, AuthUserFile, Require, etc.).
FileInfo
Permet l'utilisation des directives qui contr�lent les types de documents (directives DefaultType, ErrorDocument, ForceType, LanguagePriority, SetHandler, SetInputFilter, SetOutputFilter, et directives du module mod_mime Add* et Remove*, etc...), des metadonn�es des documents (Header, RequestHeader, SetEnvIf, SetEnvIfNoCase, BrowserMatch, CookieExpires, CookieDomain, CookieStyle, CookieTracking, CookieName), des directives du module mod_rewrite (RewriteEngine, RewriteOptions, RewriteBase, RewriteCond, RewriteRule), des directives du module mod_alias directives (Redirect, RedirectTemp, RedirectPermanent, RedirectMatch), et de la directive Action du module mod_actions.
Indexes
Permet l'utilisation des directives qui contr�lent l'indexation des r�pertoires (AddDescription, AddIcon, AddIconByEncoding, AddIconByType, DefaultIcon, DirectoryIndex, FancyIndexing, HeaderName, IndexIgnore, IndexOptions, ReadmeName, etc...).
Limit
Permet l'utilisation des directives contr�lant l'acc�s au serveur (Allow, Deny et Order).
Options[=Option,...]
Permet l'utilisation des directives contr�lant les fonctionnalit�s sp�cifiques d'un r�pertoire (Options et XBitHack). "Options" doit �tre suivi d'un signe "�gal", puis d'une liste d'options s�par�es par des virgules (pas d'espaces) ; ces options doivent �tre d�finies � l'aide de la commande Options.

D�sactivation implicite des options

Bien que la liste des options disponibles dans les fichiers .htaccess puisse �tre limit�e par cette directive, tant qu'un directive Options est autoris�e, toute autre option h�rit�e peut �tre d�sactiv�e en utilisant la syntaxe non-relative. En d'autres termes, ce m�canisme ne peut pas forcer une option sp�cifique � rester activ�e tout en permettant � toute autre option d'�tre activ�e.

Exemple :

AllowOverride AuthConfig Indexes

Dans l'exemple ci-dessus, toutes les directives qui ne font partie ni du groupe AuthConfig, ni du groupe Indexes, provoquent une "internal server error".

Pour des raisons de s�curit� et de performances, n'affectez pas � AllowOverride une autre valeur que None dans votre bloc <Directory />. Configurez plut�t le bloc <Directory> qui concerne le r�pertoire dans lequel vous voulez placer votre fichier .htaccess (ou cr�ez-le s'il n'existe pas).

Voir aussi

top

AuthName Directive

Description:Identificateur d'autorisation � utiliser pour l'authentification HTTP
Syntaxe:AuthName domaine d'authentification
Contexte:r�pertoire, .htaccess
AllowOverride:AuthConfig
Statut:Core
Module:core

Cette directive permet de d�finir l'identificateur d'autorisation pour un r�pertoire. Cet identificateur est fourni au client afin que ce dernier sache quels nom d'utilisateur et mot de passe envoyer. AuthName n'accepte qu'un seul argument ; si l'identificateur contient des espaces, il doit �tre entour� d'apostrophes. Il doit �tre associ� � des directives AuthType et Require, ainsi qu'� des directives telles que AuthUserFile et AuthGroupFile pour pouvoir fonctionner.

Par exemple :

AuthName "Top Secret"

La cha�ne de caract�res d�finie par la directive AuthName correspond � celle que la plupart des navigateurs vont fournir dans la bo�te de dialogue de saisie du mot de passe.

Voir aussi

top

AuthType Directive

Description:Le type d'authentification de l'utilisateur
Syntaxe:AuthType Basic|Digest
Contexte:r�pertoire, .htaccess
AllowOverride:AuthConfig
Statut:Core
Module:core

Cette directive permet de d�finir le type d'authentification de l'utilisateur pour un r�pertoire. Les types d'authentification disponibles sont Basic (impl�ment� par mod_auth_basic), et Digest (impl�ment� par mod_auth_digest).

Pour que l'authentification fonctionne, vous devez aussi d�finir les directives AuthName et Require. En outre, le serveur doit avoir � sa disposition un module fournisseur d'authentification tel que mod_authn_file et un module d'autorisation tel que mod_authz_user.

Voir aussi

top

CGIMapExtension Directive

Description:Technique permettant de localiser l'interpr�teur des scripts CGI
Syntaxe:CGIMapExtension chemin CGI .extension
Contexte:r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core
Compatibilit�:NetWare uniquement

Cette directive permet de contr�ler la mani�re dont Apache trouve l'interpr�teur servant � ex�cuter les scripts CGI. Par exemple, avec la d�finition CGIMapExtension sys:\foo.nlm .foo, tous les fichiers scripts CGI poss�dant une extension .foo seront pass�s � l'interpr�teur FOO.

top

ContentDigest Directive

Description:Active la g�n�ration d'un en-t�te Content-MD5 dans la r�ponse HTTP
Syntaxe:ContentDigest On|Off
D�faut:ContentDigest Off
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:Options
Statut:Core
Module:core

Cette directive active la g�n�ration d'un en-t�te Content-MD5 selon les d�finitions des RFC 1864 et 2616.

MD5 est un algorithme permettant de g�n�rer un condens� (parfois appel� "empreinte") � partir de donn�es d'une taille al�atoire ; le degr� de pr�cision est tel que la moindre alt�ration des donn�es d'origine entra�ne une alt�ration de l'empreinte.

L'en-t�te Content-MD5 permet de v�rifier l'int�grit� de la r�ponse HTTP dans son ensemble. Un serveur mandataire ou un client peut utiliser cet en-t�te pour rechercher une �ventuelle modification accidentelle de la r�ponse au cours de sa transmission. Exemple d'en-t�te :

Content-MD5: AuLb7Dp1rqtRtxz2m9kRpA==

Notez que des probl�mes de performances peuvent affecter votre serveur, car l'empreinte est g�n�r�e pour chaque requ�te (il n'y a pas de mise en cache).

L'en-t�te Content-MD5 n'est envoy� qu'avec les documents servis par le module core, � l'exclusion de tout autre module. Ainsi, les documents SSI, les sorties de scripts CGI, et les r�ponses � des requ�tes partielles (byte range) ne comportent pas cet en-t�te.

top

DefaultType Directive

Description:Type de contenu MIME qui sera envoy� par d�faut si le serveur ne peut le d�terminer d'aucune mani�re
Syntaxe:DefaultType type MIME|none
D�faut:DefaultType text/plain
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core
Compatibilit�:L'argument none est disponible dans les versions d'Apache 2.2.7 et sup�rieures

Il peut arriver que le serveur doive servir un document dont il ne peut pas d�terminer le type � partir de sa table de types MIME.

Le serveur DEVRAIT fournir au client le type de contenu du document. Si le serveur n'est pas capable de le d�terminer par la voie normale, il fournira le type d�fini par la directive DefaultType. Par exemple :

DefaultType image/gif

conviendra pour un r�pertoire contenant de nombreuses images GIF dont le fichier ne comporte pas l'extension .gif.

Dans les cas o� ni le serveur, ni l'administrateur (ou un serveur mandataire) ne sont en mesure de d�terminer le type du document, il est pr�f�rable de ne pas le mentionner, plut�t que de fournir de fausses informations. � cet effet, on utilise

DefaultType None

DefaultType None n'est disponible que dans les versions d'Apache 2.2.7 et sup�rieures.

Notez qu'� la diff�rence de la directive ForceType, cette directive ne d�finit que le type MIME par d�faut. Toute autre d�finition de type MIME, y compris l'extension des noms de fichiers, susceptible de permettre d'identifier le type de m�dia l'emportera sur la valeur par d�faut.

top

<Directory> Directive

Description:Regroupe un ensemble de directives qui ne s'appliquent qu'au r�pertoire concern� du syst�me de fichiers, � ses sous-r�pertoires, et � leur contenu.
Syntaxe:<Directory chemin r�pertoire> ... </Directory>
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

Les balises <Directory> et </Directory> permettent de regrouper un ensemble de directives qui ne s'appliquent qu'au r�pertoire pr�cis�, � ses sous-r�pertoires, et aux fichiers situ�s dans ces sous-r�pertoires. Toute directive autoris�e dans un contexte de r�pertoire peut �tre utilis�e. chemin r�pertoire est soit le chemin absolu d'un r�pertoire, soit une cha�ne de caract�res avec caract�res g�n�riques utilisant la comparaison Unix de style shell. Dans une cha�ne de caract�res avec caract�res g�n�riques, ? correspond � un caract�re quelconque, et * � toute cha�ne de caract�res. Les intervalles de caract�res [] sont aussi autoris�s. Aucun caract�re g�n�rique ne peut remplacer le caract�re `/', si bien que l'expression <Directory /*/public_html> ne conviendra pas pour le chemin * /home/user/public_html, alors que <Directory /home/*/public_html> conviendra. Exemple :

<Directory /usr/local/httpd/htdocs>
Options Indexes FollowSymLinks
</Directory>

Soyez prudent avec l'argument chemin r�pertoire : il doit correspondre exactement au chemin du syst�me de fichier qu'Apache utilise pour acc�der aux fichiers. Les directives comprises dans une section <Directory> ne s'appliqueront pas aux fichiers du m�me r�pertoire auxquels on aura acc�d� via un chemin diff�rent, per exemple via un lien symbolique.

Les Expressions rationnelles peuvent aussi �tre utilis�es en ajoutant le caract�re ~. Par exemple :

<Directory ~ "^/www/[0-9]{3}">

pourra correspondre � tout r�pertoire situ� dans /www/ et dont le nom se compose de trois chiffres.

Si plusieurs sections <Directory> (sans expression rationnelle) correspondent au r�pertoire (ou � un de ses parents) qui contient le document, les directives de la section <Directory> dont le chemin est le plus court sont appliqu�es en premier, en s'intercalant avec les directives des fichiers .htaccess. Par exemple, avec

<Directory />
AllowOverride None
</Directory>

<Directory /home>
AllowOverride FileInfo
</Directory>

l'acc�s au document /home/web/dir/doc.html emprunte le chemin suivant :

Les directives associ�es aux r�pertoires sous forme d'expressions rationnelles ne sont prises en compte qu'une fois toutes les directives des sections sans expressions rationnelles appliqu�es. Alors, tous les r�pertoires avec expressions rationnelles sont test�s selon l'ordre dans lequel ils apparaissent dans le fichier de configuration. Par exemple, avec

<Directory ~ "public_html/.*">
# ... directives here ...
</Directory>

la section avec expression rationnelle ne sera prise en compte qu'apr�s les sections <Directory> sans expressions rationnelles et les fichiers .htaccess. Alors, l'expression rationnelle conviendra pour /home/abc/public_html/abc et la section <Directory> correspondante s'appliquera.

Notez que pour Apache, la politique d'acc�s par d�faut dans les sections <Directory /> est Allow from All. Ceci signifie qu'Apache va servir tout fichier correspondant � une URL. Il est recommand� de modifier cette situation � l'aide d'un bloc du style

<Directory />
Order Deny,Allow
Deny from All
</Directory>

puis d'affiner la configuration pour les r�pertoires que vous voulez rendre accessibles. Voir la page Conseils � propos de la s�curit� pour plus de d�tails.

Les sections directory se situent dans le fichier httpd.conf. Les directives <Directory> ne peuvent pas �tre imbriqu�es et ne sont pas autoris�es dans les sections <Limit> ou <LimitExcept>.

Voir aussi

top

<DirectoryMatch> Directive

Description:Regroupe des directives qui s'appliquent � des r�pertoires du syst�me de fichiers correspondant � une expression rationnelle et � leurs sous-r�pertoires
Syntaxe:<DirectoryMatch regex> ... </DirectoryMatch>
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

Les balises <DirectoryMatch> et </DirectoryMatch> permettent de regrouper un ensemble de directives qui ne s'appliqueront qu'au r�pertoire pr�cis� (et aux fichiers qu'il contient), comme pour la section <Directory>. Cependant, le r�pertoire est pr�cis� sous la forme d'une expression rationnelle. Par exemple :

<DirectoryMatch "^/www/(.+/)?[0-9]{3}">

conviendrait pour les sous-r�pertoires de /www/ dont le nom se compose de trois chiffres.

Caract�re de fin de ligne

Cette directive ne tient pas compte du caract�re de fin de ligne ($).

Voir aussi

top

DocumentRoot Directive

Description:Racine de l'arborescence des documents principale visible depuis Internet
Syntaxe:DocumentRoot chemin r�pertoire
D�faut:DocumentRoot /usr/local/apache/htdocs
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

Cette directive permet de d�finir le r�pertoire � partir duquel httpd va servir les fichiers. S'il ne correspond pas � un Alias, le chemin de l'URL sera ajout� par le serveur � la racine des documents afin de construire le chemin du document recherch�. Exemple :

DocumentRoot /usr/web

un acc�s � http://www.my.host.com/index.html se r�f�re alors � /usr/web/index.html. Si chemin r�pertoire n'est pas un chemin absolu, il est consid�r� comme relatif au chemin d�fini par la directive ServerRoot.

Le r�pertoire d�fini par la directive DocumentRoot ne doit pas comporter de slash terminal.

Voir aussi

top

EnableMMAP Directive

Description:Utilise la projection en m�moire (Memory-Mapping) pour lire les fichiers pendant qu'ils sont servis
Syntaxe:EnableMMAP On|Off
D�faut:EnableMMAP On
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core

Cette directive d�finit si httpd peut utiliser la projection en m�moire (Memory-Mapping) s'il doit lire le contenu d'un fichier pendant qu'il est servi. Par d�faut, lorsque le traitement d'une requ�te requiert l'acc�s aux donn�es contenues dans un fichier -- par exemple, pour servir un fichier interpr�t� par le serveur � l'aide de mod_include -- Apache projette le fichier en m�moire si le syst�me d'exploitation le permet.

Cette projection en m�moire induit parfois une am�lioration des performances. Cependant, sur certains syst�mes, il est pr�f�rable de d�sactiver la projection en m�moire afin d'�viter certains probl�mes op�rationnels :

Pour les configurations de serveur sujettes � ce genre de probl�me, il est pr�f�rable de d�sactiver la projection en m�moire des fichiers servis en sp�cifiant :

EnableMMAP Off

Pour les montages NFS, cette fonctionnalit� peut �tre explicitement d�sactiv�e pour les fichiers concern�s en sp�cifiant :

<Directory "/chemin vers montage NFS"> EnableMMAP Off </Directory>

top

EnableSendfile Directive

Description:Utilise le support sendfile du noyau pour servir les fichiers aux clients
Syntaxe:EnableSendfile On|Off
D�faut:EnableSendfile On
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core
Compatibilit�:Disponible dans les versions 2.0.44 et sup�rieures

Cette directive d�finit si le programme httpd peut utiliser le support sendfile du noyau pour transmettre le contenu des fichiers aux clients. Par d�faut, lorsque le traitement d'une requ�te ne requiert pas l'acc�s aux donn�es contenues dans un fichier -- par exemple, pour la transmission d'un fichier statique -- Apache utilise sendfile pour transmettre le contenu du fichier sans m�me lire ce dernier, si le syst�me d'exploitation le permet.

Ce m�canisme sendfile �vite la s�paration des op�rations de lecture et d'envoi, ainsi que les r�servations de tampons. sur certains syst�mes cependant, ou sous certains syst�mes de fichiers, il est pr�f�rable de d�sactiver cette fonctionnalit� afin d'�viter certains probl�mes op�rationnels :

Pour les configurations de serveur sujettes � ce genre de probl�me, il est recommand� de d�sactiver cette fonctionnalit� en sp�cifiant :

EnableSendfile Off

Pour les montages NFS ou SMB, cette fonctionnalit� peut �tre explicitement d�sactiv�e pour les fichiers concern�s en sp�cifiant :

<Directory "/chemin vers montage r�seau"> EnableSendfile Off </Directory>

Veuillez noter que la configuration de la directive EnableSendfile dans un contexte de r�pertoire ou de fichier .htaccess n'est pas support�e par mod_disk_cache. Le module ne prend en compte la d�finition de EnableSendfile que dans un contexte global.

top

ErrorDocument Directive

Description:Document que le serveur renvoie au client en cas d'erreur
Syntaxe:ErrorDocument code erreur document
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core
Compatibilit�:La syntaxe des guillemets pour les messages textes est diff�rente dans Apache 2.0

Apache peut traiter les probl�mes et les erreurs de quatre mani�res,

  1. afficher un simple message d'erreur au contenu fixe
  2. afficher un message personnalis�
  3. rediriger en interne vers un chemin d'URL local pour traiter le probl�me ou l'erreur
  4. rediriger vers une URL externe pour traiter le probl�me ou l'erreur

La premi�re option constitue le comportement par d�faut; pour choisir une des trois autres options, il faut configurer Apache � l'aide de la directive ErrorDocument, suivie du code de la r�ponse HTTP et d'une URL ou d'un message. Apache fournit parfois des informations suppl�mentaires � propos du probl�me ou de l'erreur.

Les URLs peuvent commencer par un slash (/) pour les chemins web locaux (relatifs au r�pertoire d�fini par la directive DocumentRoot), ou se pr�senter sous la forme d'une URL compl�te que le client pourra r�soudre. Alternativement, un message � afficher par le navigateur pourra �tre fourni. Exemples :

ErrorDocument 500 http://foo.example.com/cgi-bin/tester
ErrorDocument 404 /cgi-bin/bad_urls.pl
ErrorDocument 401 /subscription_info.html
ErrorDocument 403 "D�sol�, vous n'avez pas l'autorisation d'acc�s aujourd'hui"

De plus, on peut sp�cifier la valeur sp�ciale default pour indiquer l'utilisation d'un simple message d'Apache cod� en dur. Bien que non n�cessaire dans des circonstances normales, la sp�cification de la valeur default va permettre de r�tablir l'utilisation du simple message d'Apache cod� en dur pour les configurations qui sans cela, h�riteraient d'une directive ErrorDocument existante.

ErrorDocument 404 /cgi-bin/bad_urls.pl

<Directory /web/docs>
ErrorDocument 404 default
</Directory>

Notez que lorsque vous sp�cifiez une directive ErrorDocument pointant vers une URL distante (c'est � dire tout ce qui commence par le pr�fixe http), Apache va envoyer une redirection au client afin de lui indiquer o� trouver le document, m�me dans le cas o� ce document se trouve sur le serveur local. Ceci a de nombreuses cons�quences dont la plus importante r�side dans le fait que le client ne recevra pas le code d'erreur original, mais au contraire un code de statut de redirection. Ceci peut en retour semer la confusion chez les robots web et divers clients qui tentent de d�terminer la validit� d'une URL en examinant le code de statut. De plus, si vous utilisez une URL distante avec ErrorDocument 401, le client ne saura pas qu'il doit demander un mot de passe � l'utilisateur car il ne recevra pas le code de statut 401. C'est pourquoi, si vous utilisez une directive ErrorDocument 401, elle devra faire r�f�rence � un document par le biais d'un chemin local.

Microsoft Internet Explorer (MSIE) ignore par d�faut les messages d'erreur g�n�r�s par le serveur lorsqu'ils sont trop courts et remplacent ces propres messages d'erreur "amicaux". Le seuil de taille varie en fonction du type d'erreur, mais en g�n�ral, si la taille de votre message d'erreur est sup�rieure � 512 octets, il y a peu de chances pour que MSIE l'occulte, et il sera affich� par ce dernier. Vous trouverez d'avantage d'informations dans l'article de la base de connaissances Microsoft Q294807.

Bien que la plupart des messages d'erreur internes originaux puissent �tre remplac�s, ceux-ci sont cependant conserv�s dans certaines circonstances sans tenir compte de la d�finition de la directive ErrorDocument. En particulier, en cas de d�tection d'une requ�te mal form�e, le processus de traitement normal des requ�tes est imm�diatement interrompu, et un message d'erreur interne est renvoy�, ceci afin de se pr�munir contre les probl�mes de s�curit� li�s aux requ�tes mal form�es.

Si vous utilisez mod_proxy, il est en g�n�ral pr�f�rable d'activer ProxyErrorOverride afin d'�tre en mesure de produire des messages d'erreur personnalis�s pour le compte de votre serveur d'origine. Si vous n'activez pas ProxyErrorOverride, Apache ne g�n�rera pas de messages d'erreur personnalis�s pour le contenu mandat�.

Avant la version 2.0, les messages �taient indiqu�s en les pr�fixant par un seul caract�re guillemet isol�.

Voir aussi

top

ErrorLog Directive

Description:D�finition du chemin du journal des erreurs
Syntaxe: ErrorLog chemin fichier|syslog[:facility]
D�faut:ErrorLog logs/error_log (Unix) ErrorLog logs/error.log (Windows et OS/2)
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

La directive ErrorLog permet de d�finir le nom du fichier dans lequel le serveur va journaliser toutes les erreurs qu'il rencontre. Si le chemin fichier n'est pas absolu, il est consid�re comme relatif au chemin d�fini par la directive ServerRoot.

Exemple

ErrorLog /var/log/httpd/error_log

Si le chemin fichier commence par une barre verticale "|", il est consid�r� comme une commande � lancer pour traiter la journalisation de l'erreur.

Exemple

ErrorLog "|/usr/local/bin/erreurs_httpd"

Voir les notes � propos des journaux redirig�s pour plus de d�tails.

L'utilisation de syslog � la place d'un nom de fichier active la journalisation via syslogd(8) si le syst�me le supporte. Le dispositif syslog par d�faut est local7, mais vous pouvez le modifier � l'aide de la syntaxe syslog:facility, o� facility peut �tre remplac� par un des noms habituellement document�s dans la page de man syslog(1).

Exemple

ErrorLog syslog:user

SECURITE : Voir le document conseils � propos de s�curit� pour des d�tails sur les raisons pour lesquelles votre s�curit� peut �tre compromise si le r�pertoire contenant les fichiers journaux pr�sente des droits en �criture pour tout autre utilisateur que celui sous lequel le serveur est d�marr�.

Note

Lors de la sp�cification d'un chemin de fichier sur les plates-formes non-Unix, on doit veiller � n'utiliser que des slashes (/), m�me si la plate-forme autorise l'utilisation des anti-slashes (\). Et d'une mani�re g�n�rale, il est recommand� de n'utiliser que des slashes (/) dans les fichiers de configuration.

Voir aussi

top

FileETag Directive

Description:Caract�ristiques de fichier utilis�s lors de la g�n�ration de l'en-t�te de r�ponse HTTP ETag pour les fichiers statiques
Syntaxe:FileETag composant ...
D�faut:FileETag INode MTime Size
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core

La directive FileETag d�finit les caract�ristiques de fichier utilis�es lors de la g�n�ration de l'en-t�te de r�ponse HTTP ETag (entity tag) quand le document est contenu dans un fichier statique (la valeur de ETag est utilis�e dans le cadre de la gestion du cache pour pr�server la bande passante r�seau). Dans les versions 1.3.22 et ant�rieures d'Apache, la valeur de l'en-t�te ETag se composait toujours de l'inode du fichier, de sa taille et de sa date de derni�re modification (mtime). La directive FileETag vous permet d�sormais de choisir quelles caract�ristiques du fichier vont �tre �ventuellement utilis�es. Les mots-cl�s reconnus sont :

INode
Le num�ro d'i-node du fichier sera inclus dans le processus de g�n�ration
MTime
La date et l'heure auxquelles le fichier a �t� modifi� la derni�re fois seront incluses
Size
La taille du fichier en octets sera incluse
All
Tous les champs disponibles seront utilis�s. Cette d�finition est �quivalente � :

FileETag INode MTime Size

None
Si le document se compose d'un fichier, aucun champ ETag ne sera inclus dans la r�ponse

Les mots-cl�s INode, MTime, et Size peuvent �tre pr�fix�s par + ou -, ce qui permet de modifier les valeurs par d�faut h�rit�es d'un niveau de configuration plus g�n�ral. Tout mot-cl� apparaissant sans aucun pr�fixe annule enti�rement et imm�diatement les configurations h�rit�es.

Si la configuration d'un r�pertoire contient FileETag INode MTime Size, et si un de ses sous-r�pertoires contient FileETag -INode, la configuration de ce sous-r�pertoire (qui sera propag�e vers tout sous-r�pertoire qui ne la supplante pas), sera �quivalente � FileETag MTime Size.

Avertissement

Ne modifiez pas les valeurs par d�faut pour les r�pertoires ou localisations o� WebDAV est activ� et qui utilisent mod_dav_fs comme fournisseur de stockage. mod_dav_fs utilise INode MTime Size comme format fixe pour les comparaisons de champs ETag dans les requ�tes conditionnelles. Ces requ�tes conditionnelles �choueront si le format ETag est modifi� via la directive FileETag.

Inclusions c�t� serveur

Aucun champ ETag n'est g�n�r� pour les r�ponses interpr�t�es par mod_include, car l'entit� de la r�ponse peut changer sans modification de l'INode, du MTime, ou de la taille du fichier statique contenant les directives SSI.
top

<Files> Directive

Description:Contient des directives qui s'appliquent aux fichiers pr�cis�s
Syntaxe:<Files nom fichier> ... </Files>
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:All
Statut:Core
Module:core

La directive <Files> limite la port�e des directives qu'elle contient aux fichiers pr�cis�s. Elle est comparable aux directives <Directory> et <Location>. Elle doit se terminer par une balise </Files>. Les directives contenues dans cette section s'appliqueront � tout objet dont le nom de base (la derni�re partie du nom de fichier) correspond au fichier sp�cifi�. Les sections <Files> sont trait�es selon l'ordre dans lequel elles apparaissent dans le fichier de configuration, apr�s les sections <Directory> et la lecture des fichiers .htaccess, mais avant les sections <Location>. Notez que les sections <Files> peuvent �tre imbriqu�es dans les sections <Directory> afin de restreindre la portion du syst�me de fichiers � laquelle ces derni�res vont s'appliquer.

L'argument filename peut contenir un nom de fichier ou une cha�ne de caract�res avec caract�res g�n�riques, o� ? remplace un caract�re, et * toute cha�ne de caract�res :

<Files "cat.html">
    # Ins�rer ici les directives s'appliquant au fichier cat.html
</Files>

<Files "?at.*">
    # Les directives ins�r�es ici s'appliqueront aux fichiers cat.html,
    # bat.html, hat.php et ainsi de suite.
</Files>

On peut aussi utiliser les Expressions rationnelles en ajoutant la caract�re ~. Par exemple :

<Files ~ "\.(gif|jpe?g|png)$">

correspondrait � la plupart des formats graphiques de l'Internet. Il est cependant pr�f�rable d'utiliser la directive <FilesMatch>.

Notez qu'� la diff�rence des sections <Directory> et <Location>, les sections <Files> peuvent �tre utilis�es dans les fichiers .htaccess. Ceci permet aux utilisateurs de contr�ler l'acc�s � leurs propres ressources, fichier par fichier.

Voir aussi

top

<FilesMatch> Directive

Description:Contient des directives qui s'appliquent � des fichiers sp�cifi�s sous la forme d'expressions rationnelles
Syntaxe:<FilesMatch expression rationnelle> ... </FilesMatch>
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:All
Statut:Core
Module:core

La section <FilesMatch> limite la port�e des directives qu'elle contient aux fichiers sp�cifi�s, tout comme le ferait une section <Files>. Mais elle accepte aussi les expressions rationnelles. Par exemple :

<FilesMatch "\.(gif|jpe?g|png)$">

correspondrait � la plupart des formats graphiques de l'Internet.

Voir aussi

top

ForceType Directive

Description:Force un type de contenu MIME pour les fichiers sp�cifi�s
Syntaxe:ForceType type MIME|None
Contexte:r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core
Compatibilit�:Int�gr� dans le coeur d'Apache depuis la version 2.0

Lorsqu'elle est plac�e dans un fichier .htaccess ou une section <Directory>, <Location>, ou <Files>, cette directive force l'identification du type MIME des fichiers sp�cifi�s � la valeur de l'argument type MIME. Par exemple, si vous poss�dez un r�pertoire ne contenant que des fichiers GIF, et si vous ne voulez pas leur ajouter l'extension .gif, vous pouvez utiliser :

ForceType image/gif

Notez qu'� la diff�rence de DefaultType, cette directive l'emporte sur toute m�thode d'attribution du type MIME, y compris les extensions de nom de fichier, qui parviendrait � identifier le type de m�dium.

Vous pouvez annuler toute autre d�finition ForceType en affectant la valeur None � l'argument type MIME :

# force le type MIME de tous les fichiers � image/gif:
<Location /images>
ForceType image/gif
</Location>

# mais utilise les m�thodes classiques d'attribution du type MIME # dans le sous-r�pertoire suivant :
<Location /images/mixed>
ForceType None
</Location>

top

GprofDir Directive

Description:R�pertoire dans lequel �crire les donn�es de profiling gmon.out.
Syntaxe:GprofDir /tmp/gprof/|/tmp/gprof/%
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

Lorsque le serveur a �t� compil� avec le support du profiling gprof, la directive GprofDir permet de sp�cifier dans quel r�pertoire les fichiers gmon.out doivent �tre �crits lorsque le processus s'arr�te. Si l'argument se termine par un caract�re pourcentage ('%'), des sous-r�pertoires sont cr��s pour chaque identifiant de processus.

Cette directive ne fonctionne actuellement qu'avec le MPM prefork.

top

HostnameLookups Directive

Description:Active la recherche DNS sur les adresses IP des clients
Syntaxe:HostnameLookups On|Off|Double
D�faut:HostnameLookups Off
Contexte:configuration du serveur, serveur virtuel, r�pertoire
Statut:Core
Module:core

Cette directive active la recherche DNS afin de pouvoir journaliser les noms d'h�tes (et les passer aux programmes CGI et aux inclusions SSI via la variable REMOTE_HOST). La valeur Double d�clenche une double recherche DNS inverse. En d'autres termes, une fois la recherche inverse effectu�e, on lance une recherche directe sur le r�sultat de cette derni�re. Au moins une des adresses IP fournies par la recherche directe doit correspondre � l'adresse originale (ce que l'on nomme PARANOID dans la terminologie "tcpwrappers").

Quelle que soit la configuration, lorsqu'on utilise mod_authz_host pour contr�ler l'acc�s en fonction du nom d'h�te, une double recherche DNS inverse est effectu�e, s�curit� oblige. Notez cependant que le r�sultat de cette double recherche n'est en g�n�ral pas accessible, � moins que vous n'ayez sp�cifi� HostnameLookups Double. Par exemple, si vous n'avez sp�cifi� que HostnameLookups On, et si une requ�te concerne un objet prot�g� par des restrictions en fonction du nom d'h�te, quel que soit le r�sultat de la double recherche inverse, les programmes CGI ne recevront que le r�sultat de la recherche inverse simple dans la variable REMOTE_HOST.

La valeur par d�faut est Off afin de pr�server le traffic r�seau des sites pour lesquels la recherche inverse n'est pas vraiment n�cessaire. Cette valeur par d�faut est aussi b�n�fique pour les utilisateurs finaux car il n'ont ainsi pas � subir de temps d'attente suppl�mentaires dus aux recherches DNS. Les sites fortement charg�s devraient laisser cette directive � Off, car les recherches DNS peuvent prendre des temps tr�s longs. Vous pouvez �ventuellement utiliser hors ligne l'utilitaire logresolve, compil� par d�faut dans le sous-r�pertoire bin de votre r�pertoire d'installation, afin de d�terminer les noms d'h�tes associ�s aux adresses IP journalis�es.

top

<IfDefine> Directive

Description:Contient des directives qui ne s'appliqueront que si un test retourne "vrai" au d�marrage du serveur
Syntaxe:<IfDefine [!]param�tre> ... </IfDefine>
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:All
Statut:Core
Module:core

La section <IfDefine test>...</IfDefine> permet de conf�rer un caract�re conditionnel � un ensemble de directives. Les directives situ�es � l'int�rieur d'une section <IfDefine> ne s'appliquent que si test est vrai. Si test est faux, tout ce qui se trouve entre les balises de d�but et de fin est ignor�.

test peut se pr�senter sous deux formes :

Dans le premier cas, les directives situ�es entre les balises de d�but et de fin ne s'appliqueront que si le param�tre nomm� nom param�tre est d�fini. Le second format inverse le test, et dans ce cas, les directives ne s'appliqueront que si nom param�tre n'est pas d�fini.

La d�finition de l'argument nom param�tre s'effectue au niveau de la ligne de commande httpd via le param�tre -Dparam�tre au d�marrage du serveur.

Les sections <IfDefine> peuvent �tre imbriqu�es, ce qui permet de mettre en oeuvre un test multi-param�tres simple. Exemple :

httpd -DReverseProxy -DUseCache -DMemCache ...

# httpd.conf
<IfDefine ReverseProxy>
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_http_module modules/mod_proxy_http.so
<IfDefine UseCache>
LoadModule cache_module modules/mod_cache.so
<IfDefine MemCache>
LoadModule mem_cache_module modules/mod_mem_cache.so
</IfDefine>
<IfDefine !MemCache>
LoadModule disk_cache_module modules/mod_disk_cache.so
</IfDefine>
</IfDefine>
</IfDefine>

top

<IfModule> Directive

Description:Contient des directives qui ne s'appliquent qu'en fonction de la pr�sence ou de l'absence d'un module sp�cifique
Syntaxe:<IfModule [!]fichier module|identificateur module> ... </IfModule>
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:All
Statut:Core
Module:core
Compatibilit�:Les identificateurs de modules sont disponibles dans les versions 2.1 et sup�rieures.

La section <IfModule test>...</IfModule> permet de conf�rer � des directives un caract�re conditionnel bas� sur la pr�sence d'un module sp�cifique. Les directives situ�es dans une section <IfModule> ne s'appliquent que si test est vrai. Si test est faux, tout ce qui se trouve entre les balises de d�but et de fin est ignor�.

test peut se pr�senter sous deux formes :

Dans le premier cas, les directives situ�es entre les balises de d�but et de fin ne s'appliquent que si le module module est pr�sent -- soit compil� avec le binaire httpd, soit charg� dynamiquement via la directive LoadModule. Le second format inverse le test, et dans ce cas, les directives ne s'appliquent que si module n'est pas pr�sent.

L'argument module peut contenir soit l'identificateur du module, soit le nom du fichier source du module. Par exemple, rewrite_module est un identificateur et mod_rewrite.c le nom du fichier source correspondant. Si un module comporte plusieurs fichiers sources, utilisez le nom du fichier qui contient la cha�ne de caract�res STANDARD20_MODULE_STUFF.

Les sections <IfModule> peuvent �tre imbriqu�es, ce qui permet d'impl�menter des tests multi-modules simples.

Cette section ne doit �tre utilis�e que si votre fichier de configuration ne fonctionne qu'en fonction de la pr�sence ou de l'absence d'un module sp�cifique. D'une mani�re g�n�rale, il n'est pas n�cessaire de placer les directives � l'int�rieur de sections <IfModule>.
top

Include Directive

Description:Inclut d'autres fichiers de configuration dans un des fichiers de configuration du serveur
Syntaxe:Include chemin fichier|chemin r�pertoire
Contexte:configuration du serveur, serveur virtuel, r�pertoire
Statut:Core
Module:core
Compatibilit�:Utilisation des caract�res g�n�riques depuis la version 2.0.41, utilisation des caract�res g�n�riques pour les r�pertoires depuis la version 2.3.6

Cette directive permet l'inclusion d'autres fichiers de configuration dans un des fichiers de configuration du serveur.

On peut utiliser des caract�res g�n�riques de style Shell (fnmatch()) dans le nom du fichier ou la partie r�pertoire pour inclure plusieurs fichiers en une seule fois, selon leur ordre alphab�tique. De plus, si la directive Include pointe vers un r�pertoire, Apache inclura tous les fichiers de ce r�pertoire et de tous ces sous-r�pertoires. L'inclusion de r�pertoires entiers est cependant d�conseill�e, car il est fr�quent d'oublier des fichiers temporaires dans un r�pertoire, ce qui causerait une erreur httpd en cas d'inclusion. Nous vous recommandons plut�t d'utiliser la syntaxe avec caract�res g�n�riques vue ci-dessous pour inclure des fichiers dont le nom correspond � un mod�le particulier, comme *.conf par exemple.

Lorsqu'on utilise un caract�re g�n�rique dans le nom de fichier ou la partie r�pertoire du chemin, et si aucun fichier ou r�pertoire ne correspond au mod�le, la directive Include sera silencieusement ignor�e. Si un nom de fichier ou un r�pertoire du chemin est sp�cifi� sans caract�re g�n�rique, et si ce r�pertoire ou fichier n'existe pas, la directive Include �chouera et renverra un message d'erreur indiquant que le r�pertoire ou fichier n'a pas pu �tre trouv�. Il devient ainsi inutile de cr�er des fichiers fictifs destin�s � correspondre par d�faut � un chemin contenant des caract�res g�n�riques.

Le chemin fichier sp�cifi� peut �tre soit un chemin absolu, soit un chemin relatif au r�pertoire d�fini par la directive ServerRoot.

Exemples :

Include /usr/local/apache2/conf/ssl.conf
Include /usr/local/apache2/conf/vhosts/*.conf

ou encore, avec des chemins relatifs au r�pertoire d�fini par la directive ServerRoot :

Include conf/ssl.conf
Include conf/vhosts/*.conf

Voir aussi

top

KeepAlive Directive

Description:Active les connexions HTTP persistantes
Syntaxe:KeepAlive On|Off
D�faut:KeepAlive On
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

L'extension Keep-Alive de HTTP/1.0 et l'impl�mentation des connexions persistantes dans HTTP/1.1 ont rendu possibles des sessions HTTP de longue dur�e, ce qui permet de transmettre plusieurs requ�tes via la m�me connexion TCP. Dans certains cas, le gain en rapidit� pour des documents comportant de nombreuses images peut atteindre 50%. Pour activer les connexions persistantes, d�finissez KeepAlive On.

Pour les clients HTTP/1.0, les connexions persistantes ne seront mises en oeuvre que si elles ont �t� sp�cialement demand�es par un client. De plus, une connexion persistante avec un client HTTP/1.0 ne peut �tre utilis�e que si la taille du contenu est connue d'avance. Ceci implique que les contenus dynamiques comme les sorties CGI, les pages SSI, et les listings de r�pertoires g�n�r�s par le serveur n'utiliseront en g�n�ral pas les connexions persistantes avec les clients HTTP/1.0. Avec les clients HTTP/1.1, les connexions persistantes sont utilis�es par d�faut, sauf instructions contraires. Si le client le demande, le transfert par tron�ons de taille fixe (chunked encoding) sera utilis� afin de transmettre un contenu de longueur inconnue via une connexion persistante.

Lorsqu'un client utilise une connexion persistante, elle comptera pour une seule requ�te pour la directive MaxRequestsPerChild, quel que soit le nombre de requ�tes transmises via cette connexion.

Voir aussi

top

KeepAliveTimeout Directive

Description:Dur�e pendant laquelle le serveur va attendre une requ�te avant de fermer une connexion persistante
Syntaxe:KeepAliveTimeout secondes
D�faut:KeepAliveTimeout 5
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

Le nombre de secondes pendant lesquelles Apache va attendre une requ�te avant de fermer la connexion. La valeur du d�lai sp�cifi�e par la directive Timeout s'applique d�s qu'une requ�te a �t� re�ue.

Donner une valeur trop �l�v�e � KeepAliveTimeout peut induire des probl�mes de performances sur les serveurs fortement charg�s. Plus le d�lai est �l�v�, plus nombreux seront les processus serveur en attente de requ�tes de la part de clients inactifs.

Dans un contexte de serveur virtuel � base de nom, c'est le d�lai du premier serveur virtuel d�fini (le serveur par d�faut) parmi un ensemble de directives NameVirtualHost qui sera utilis�. Les autres valeurs seront ignor�es.

top

<Limit> Directive

Description:Restreint les contr�les d'acc�s que la section contient � certaines m�thodes HTTP
Syntaxe:<Limit m�thode [m�thode] ... > ... </Limit>
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:All
Statut:Core
Module:core

Les contr�les d'acc�s s'appliquent normalement � toutes les m�thodes d'acc�s, et c'est en g�n�ral le comportement souhait�. Dans le cas g�n�ral, les directives de contr�le d'acc�s n'ont pas � �tre plac�es dans une section <Limit>.

La directive <Limit> a pour but de limiter les effets des contr�les d'acc�s aux m�thodes HTTP sp�cifi�es. Pour toutes les autres m�thodes, les restrictions d'acc�s contenues dans la section <Limit> n'auront aucun effet. L'exemple suivant n'applique les contr�les d'acc�s qu'aux m�thodes POST, PUT, et DELETE, en laissant les autres m�thodes sans protection :

<Limit POST PUT DELETE>
Require valid-user
</Limit>

La liste des noms de m�thodes peut contenir une ou plusieurs valeurs parmi les suivantes : GET, POST, PUT, DELETE, CONNECT, OPTIONS, PATCH, PROPFIND, PROPPATCH, MKCOL, COPY, MOVE, LOCK, et UNLOCK. Le nom de m�thode est sensible � la casse. Si la valeur GET est pr�sente, les requ�tes HEAD seront aussi concern�es. La m�thode TRACE ne peut pas �tre limit�e.

Une section <LimitExcept> doit toujours �tre pr�f�r�e � une section <Limit> pour la restriction d'acc�s, car une section <LimitExcept> fournit une protection contre les m�thodes arbitraires.
top

<LimitExcept> Directive

Description:Applique les contr�les d'acc�s � toutes les m�thodes HTTP, sauf celles qui sont sp�cifi�es
Syntaxe:<LimitExcept m�thode [m�thode] ... > ... </LimitExcept>
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:All
Statut:Core
Module:core

<LimitExcept> et </LimitExcept> permettent de regrouper des directives de contr�le d'acc�s qui s'appliqueront � toutes les m�thodes d'acc�s HTTP qui ne font pas partie de la liste des arguments ; en d'autres termes, elles ont un comportement oppos� � celui de la section <Limit>, et on peut les utiliser pour contr�ler aussi bien les m�thodes standards que les m�thodes non standards ou non reconnues. Voir la documentation de la section <Limit> pour plus de d�tails.

Par exemple :

<LimitExcept POST GET>
Require valid-user
</LimitExcept>

top

LimitInternalRecursion Directive

Description:D�termine le nombre maximal de redirections internes et de sous-requ�tes imbriqu�es
Syntaxe:LimitInternalRecursion nombre [nombre]
D�faut:LimitInternalRecursion 10
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core
Compatibilit�:Disponible � partir de la version 2.0.47 d'Apache

Une redirection interne survient, par exemple, quand on utilise la directive Action qui redirige en interne la requ�te d'origine vers un script CGI. Une sous-requ�te est le m�canisme qu'utilise Apache pour d�terminer ce qui se passerait pour un URI s'il faisait l'objet d'une requ�te. Par exemple, mod_dir utilise les sous-requ�tes pour rechercher les fichiers list�s dans la directive DirectoryIndex.

La directive LimitInternalRecursion permet d'�viter un crash du serveur d� � un bouclage infini de redirections internes ou de sous-requ�tes. De tels bouclages sont dus en g�n�ral � des erreurs de configuration.

La directive accepte, comme arguments, deux limites qui sont �valu�es � chaque requ�te. Le premier nombre est le nombre maximum de redirections internes qui peuvent se succ�der. Le second nombre d�termine la profondeur d'imbrication maximum des sous-requ�tes. Si vous ne sp�cifiez qu'un seul nombre, il sera affect� aux deux limites.

Exemple

LimitInternalRecursion 5

top

LimitRequestBody Directive

Description:limite la taille maximale du corps de la requ�te HTTP envoy�e par le client
Syntaxe:LimitRequestBody octets
D�faut:LimitRequestBody 0
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:All
Statut:Core
Module:core

Cette directive sp�cifie la taille maximale autoris�e pour le corps d'une requ�te ; la valeur de l'argument octets va de 0 (pour une taille illimit�e), � 2147483647 (2Go).

La directive LimitRequestBody permet de d�finir une limite pour la taille maximale autoris�e du corps d'une requ�te HTTP en tenant compte du contexte dans lequel la directive a �t� plac�e (c'est � dire au niveau du serveur, d'un r�pertoire, d'un fichier ou d'un chemin d'url). Si la requ�te du client d�passe cette limite, le serveur r�pondra par un message d'erreur et ne traitera pas la requ�te. La taille du corps d'une requ�te normale va varier de mani�re importante en fonction de la nature de la ressource et des m�thodes autoris�es pour cette derni�re. Les scripts CGI utilisent souvent le corps du message pour extraire les informations d'un formulaire. Les impl�mentations de la m�thode PUT n�cessitent une valeur au moins aussi �lev�e que la taille maximale des repr�sentations que le serveur d�sire accepter pour cette ressource.

L'administrateur du serveur peut utiliser cette directive pour contr�ler plus efficacement les comportements anormaux des requ�tes des clients, ce qui lui permettra de pr�venir certaines formes d'attaques par d�ni de service.

Si par exemple, vous autorisez le chargement de fichiers vers une localisation particuli�re, et souhaitez limiter la taille des fichiers charg�s � 100Ko, vous pouvez utiliser la directive suivante :

LimitRequestBody 102400

Note : ne s'applique pas aux requ�tes mandat�es.
top

LimitRequestFields Directive

Description:Limite le nombre de champs d'en-t�te autoris�s dans une requ�te HTTP
Syntaxe:LimitRequestFields nombre
D�faut:LimitRequestFields 100
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

nombre est un entier de 0 (nombre de champs illimit�) � 32767. La valeur par d�faut est d�finie � la compilation par la constante DEFAULT_LIMIT_REQUEST_FIELDS (100 selon la distribution).

La directive LimitRequestFields permet � l'administrateur du serveur de modifier le nombre maximum de champs d'en-t�te autoris�s dans une requ�te HTTP. Pour un serveur, cette valeur doit �tre sup�rieure au nombre de champs qu'une requ�te client normale peut contenir. Le nombre de champs d'en-t�te d'une requ�te qu'un client utilise d�passe rarement 20, mais ce nombre peut varier selon les impl�mentations des clients, et souvent en fonction des extensions que les utilisateurs configurent dans leurs navigateurs pour supporter la n�gociation de contenu d�taill�e. Les extensions HTTP optionnelles fonctionnent utilisent souvent les champs d'en-t�te des requ�tes.

L'administrateur du serveur peut utiliser cette directive pour contr�ler plus efficacement les comportements anormaux des requ�tes des clients, ce qui lui permettra de pr�venir certaines formes d'attaques par d�ni de service. La valeur sp�cifi�e doit �tre augment�e si les clients standards re�oivent une erreur du serveur indiquant que la requ�te comportait un nombre d'en-t�tes trop important.

Par exemple :

LimitRequestFields 50

Avertissement

Dans le cas des serveurs virtuels par noms, la valeur de cette directive est extraite du serveur virtuel par d�faut (le premier de la liste) pour lequel la connexion correspondait � la directive NameVirtualHost.

top

LimitRequestFieldSize Directive

Description:D�dinit la taille maximale autoris�e d'un en-t�te de requ�te HTTP
Syntaxe:LimitRequestFieldSize octets
D�faut:LimitRequestFieldSize 8190
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

Cette directive permet de d�finir le nombre maximum d'octets autoris�s dans un en-t�te de requ�te HTTP.

La directive LimitRequestFieldSize permet � l'administrateur du serveur de d�finir la taille maximale autoris�e d'un en-t�te de requ�te HTTP. Pour un serveur, cette valeur doit �tre suffisamment grande pour contenir tout en-t�te d'une requ�te client normale. La taille d'un champ d'en-t�te de requ�te normal va varier selon les impl�mentations des clients, et en fonction des extensions que les utilisateurs configurent dans leurs navigateurs pour supporter la n�gociation de contenu d�taill�e. Les en-t�tes d'authentification SPNEGO peuvent atteindre une taille de 12392 octets.

>L'administrateur du serveur peut utiliser cette directive pour contr�ler plus efficacement les comportements anormaux des requ�tes des clients, ce qui lui permettra de pr�venir certaines formes d'attaques par d�ni de service.

Par exemple ::

LimitRequestFieldSize 4094

Dans des conditions normales, la valeur par d�faut de cette directive ne doit pas �tre modifi�e.

Avertissement

Dans le cas des serveurs virtuels par noms, la valeur de cette directive est extraite du serveur virtuel par d�faut (le premier de la liste) pour lequel la connexion correspondait � la directive NameVirtualHost.

top

LimitRequestLine Directive

Description:D�finit la taille maximale d'une ligne de requ�te HTTP
Syntaxe:LimitRequestLine octets
D�faut:LimitRequestLine 8190
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

Cette directive permet de d�finir la taille maximale autoris�e pour une ligne de requ�te HTTP en octets.

La directive LimitRequestLine permet � l'administrateur du serveur de d�finir la taille maximale autoris�e d'une ligne de requ�te HTTP client. Comme une requ�te comporte une m�thode HTTP, un URI, et une version de protocole, la directive LimitRequestLine impose une restriction sur la longueur maximale autoris�e pour un URI dans une requ�te au niveau du serveur. Pour un serveur, cette valeur doit �tre suffisamment grande pour r�f�rencer les noms de toutes ses ressources, y compris toutes informations pouvant �tre ajout�es dans la partie requ�te d'une m�thode GET.

L'administrateur du serveur peut utiliser cette directive pour contr�ler plus efficacement les comportements anormaux des requ�tes des clients, ce qui lui permettra de pr�venir certaines formes d'attaques par d�ni de service.

Par exemple :

LimitRequestLine 4094

Dans des conditions normales, la valeur par d�faut de cette directive ne doit pas �tre modifi�e. En outre, vous ne pouvez pas sp�cifier une valeur sup�rieure � 8190 sans modifier le code source et recompiler.

Avertissement

Dans le cas des serveurs virtuels par noms, la valeur de cette directive est extraite du serveur virtuel par d�faut (le premier de la liste) pour lequel la connexion correspondait � la directive NameVirtualHost.

top

LimitXMLRequestBody Directive

Description:D�finit la taille maximale du corps d'une requ�te au format XML
Syntaxe:LimitXMLRequestBody octets
D�faut:LimitXMLRequestBody 1000000
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:All
Statut:Core
Module:core

Taille maximale (en octets) du corps d'une requ�te au format XML. Une valeur de 0 signifie qu'aucune limite n'est impos�e.

Exemple :

LimitXMLRequestBody 0

top

<Location> Directive

Description:N'applique les directives contenues qu'aux URLs sp�cifi�es
Syntaxe:<Location chemin URL|URL> ... </Location>
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

La directive <Location> limite la port�e des directives contenues aux URLs d�finies par l'argument URL. Elle est similaire � la directive <Directory>, et marque le d�but d'une section qui se termine par une directive </Location>. Les sections <Location> sont trait�es selon l'ordre dans lequel elles apparaissent dans le fichier de configuration, mais apr�s les sections <Directory> et la lecture des fichiers .htaccess, et apr�s les sections <Files>.

Les sections <Location> agissent compl�tement en dehors du syst�me de fichiers. Ceci a de nombreuses cons�quences. Parmi les plus importantes, on ne doit pas utiliser les sections <Location> pour contr�ler l'acc�s aux r�pertoires du syst�me de fichiers. Comme plusieurs URLs peuvent correspondre au m�me r�pertoire du syst�me de fichiers, un tel contr�le d'acc�s pourrait �tre contourn�.

Les directives que contient cette section seront appliqu�es aux requ�tes si la partie chemin de l'URL satisfait � l'un au moins de ces crit�res :

Dans l'exemple ci-dessous, o� aucun slash de fin n'est utilis�, les directives contenues dans la section s'appliqueront � /private1, /private1/ et /private1/file.txt, mais pas � /private1other.

<Location /private1> ...

De m�me, dans l'exemple ci-dessous, o� l'on utilise un slash de fin, les directives contenues dans la section s'appliqueront � /private2/ et � /private2/file.txt, mais pas � /private2other.

<Location /private2/> ...

Quand utiliser la section <Location>

Vous pouvez utiliser une section <Location> pour appliquer des directives � des contenus situ�s en dehors du syst�me de fichiers. Pour les contenus situ�s � l'int�rieur du syst�me de fichiers, utilisez plut�t les sections <Directory> et <Files>. <Location /> constitue une exception � cette r�gle et permet d'appliquer ais�ment une configuration � l'ensemble du serveur.

Pour toutes les requ�tes originales (non mandat�es), l'argument URL est un chemin d'URL de la forme /chemin/. Aucun protocole, nom d'h�te, port, ou cha�ne de requ�te ne doivent appara�tre. Pour les requ�tes mandat�es, l'URL sp�cifi�e doit �tre de la forme protocole://nom_serveur/chemin, et vous devez inclure le pr�fixe.

L'URL peut contenir des caract�res g�n�riques. Dans une cha�ne avec caract�res g�n�riques, ? correspond � un caract�re quelconque, et * � toute cha�ne de caract�res. Les caract�res g�n�riques ne peuvent pas remplacer un / dans le chemin URL.

On peut �galement utiliser les Expressions rationnelles, moyennant l'addition d'un caract�re ~. Par exemple :

<Location ~ "/(extra|special)/data">

concernerait les URLs contenant les sous-cha�ne /extra/data ou /special/data. La directive <LocationMatch> pr�sente un comportement identique � la version avec expressions rationnelles de la directive <Location>.

La directive <Location> s'utilise principalement avec la directive SetHandler. Par exemple, pour activer les requ�tes d'�tat, mais ne les autoriser que depuis des navigateurs appartenant au domaine example.com, vous pouvez utiliser :

<Location /status>
SetHandler server-status
Order Deny,Allow
Deny from all
Allow from .example.com
</Location>

Note � propos du slash (/)

La signification du caract�re slash d�pend de l'endroit o� il se trouve dans l'URL. Les utilisateurs peuvent �tre habitu�s � son comportement dans le syst�me de fichiers o� plusieurs slashes successifs sont souvent r�duits � un slash unique (en d'autres termes, /home///foo est identique � /home/foo). Dans l'espace de nommage des URLs, ce n'est cependant pas toujours le cas. Pour la directive <LocationMatch> et la version avec expressions rationnelles de la directive <Location>, vous devez sp�cifier explicitement les slashes multiples si telle est votre intention.

Par exemple, <LocationMatch ^/abc> va correspondre � l'URL /abc mais pas � l'URL //abc. La directive <Location> sans expression rationnelle se comporte de la m�me mani�re lorsqu'elle est utilis�e pour des requ�tes mandat�es. En revanche, lorsque la directive <Location> sans expression rationnelle est utilis�e pour des requ�tes non mandat�es, elle fera correspondre implicitement les slashes multiples � des slashes uniques. Par exemple, si vous sp�cifiez <Location /abc/def>, une requ�te de la forme /abc//def correspondra.

Voir aussi

top

<LocationMatch> Directive

Description:N'applique les directives contenues qu'aux URLs correspondant � une expression rationnelle
Syntaxe:<LocationMatch regex> ... </LocationMatch>
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

La directive <LocationMatch> limite la port�e des directives contenues � l'URL sp�cifi�e, de mani�re identique � la directive <Location>. Mais son argument permettant de sp�cifier les URLs concern�es est une expression rationnelle au lieu d'une simple cha�ne de caract�res. Par exemple :

<LocationMatch "/(extra|special)/data">

correspondrait � toute URL contenant les sous-cha�nes /extra/data ou /special/data.

Voir aussi

top

LogLevel Directive

Description:Contr�le la verbosit� du journal des erreurs
Syntaxe:LogLevel niveau
D�faut:LogLevel warn
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

La directive LogLevel permet d'ajuster la verbosit� des messages enregistr�s dans les journaux d'erreur (voir la directive ErrorLog directive). Les niveaux disponibles sont pr�sent�s ci-apr�s, par ordre de criticit� d�croissante :

Niveau Description Exemple
emerg Urgences - le syst�me est inutilisable. "Child cannot open lock file. Exiting"
alert Des mesures doivent �tre prises imm�diatement. "getpwuid: couldn't determine user name from uid"
crit Conditions critiques. "socket: Failed to get a socket, exiting child"
error Erreurs. "Premature end of script headers"
warn Avertissements. "child process 1234 did not exit, sending another SIGHUP"
notice Ev�nement important mais normal. "httpd: caught SIGBUS, attempting to dump core in ..."
info Informations. "Server seems busy, (you may need to increase StartServers, or Min/MaxSpareServers)..."
debug Messages de d�bogage. "Opening config file ..."

Lorsqu'un niveau particulier est sp�cifi�, les messages de tous les autres niveaux de criticit� sup�rieure seront aussi enregistr�s. Par exemple, si LogLevel info est sp�cifi�, les messages de niveaux notice et warn seront aussi �mis.

Il est recommand� d'utiliser un niveau crit ou inf�rieur.

Par exemple :

LogLevel notice

Note

Si la journalisation s'effectue directement dans un fichier, les messages de niveau notice ne peuvent pas �tre supprim�s et sont donc toujours journalis�s. Cependant, ceci ne s'applique pas lorsque la journalisation s'effectue vers syslog.

top

MaxKeepAliveRequests Directive

Description:Nombre de requ�tes permises pour une connexion persistante
Syntaxe:MaxKeepAliveRequests nombre
D�faut:MaxKeepAliveRequests 100
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

La directive MaxKeepAliveRequests permet de limiter le nombre de requ�tes autoris�es par connexion lorsque KeepAlive est � "on". Si sa valeur est 0, le nombre de requ�tes autoris�es est illimit�. Il est recommand� de d�finir une valeur assez haute pour des performances du serveur maximales.

Par exemple :

MaxKeepAliveRequests 500

top

MaxRanges Directive

Description:Nombre de segments de donn�es autoris� avant le renvoi de l'int�gralit� de la ressource
Syntaxe:MaxRanges default | unlimited | none | nombre de segments
D�faut:MaxRanges 200
Contexte:configuration du serveur, serveur virtuel, r�pertoire
Statut:Core
Module:core
Compatibilit�:Disponible depuis la version 2.2.21 du serveur HTTP Apache

La directive MaxRanges permet de limiter le nombre de segments de donn�es que le serveur va renvoyer au client. Si un nombre de segments plus important est demand�, la ressource sera renvoy�e dans son int�gralit�.

default
Limite le nombre de segments de donn�es � 200 (valeur par d�faut d�finie � la compilation).
none
Les en-t�tes Range sont ignor�s.
unlimited
Le nombre de segments de donn�es est illimit�.
nombre de segments
Un nombre positif repr�sentera la nombre de segments de donn�es maximal que le serveur renverra au client.
top

MergeTrailers Directive

Description:Determins whether trailers are merged into headers
Syntaxe:MergeTrailers [on|off]
D�faut:MergeTrailers off
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core
Compatibilit�:2.4.10 and later

La documentation de cette directive n'a pas encore t traduite. Veuillez vous reporter la version en langue anglaise.

top

NameVirtualHost Directive

Description:D�finit une adresse IP pour les serveurs virtuels � base de nom
Syntaxe:NameVirtualHost adresse[:port]
Contexte:configuration du serveur
Statut:Core
Module:core

La directive NameVirtualHost est obligatoire si vous envisagez de configurer des serveurs virtuels par nom.

Bien que adresse puisse �tre un nom d'h�te, il est recommand� d'utiliser plut�t une adresse IP et un port, dans le style

NameVirtualHost 111.22.33.44:80

La directive NameVirtualHost vous permet de sp�cifier l'adresse IP sur laquelle le serveur recevra des requ�tes pour des serveurs virtuels bas�s sur le nom. Il s'agit en g�n�ral de l'adresse � laquelle correspondent vos noms de serveurs virtuels bas�s sur le nom. Dans le cas o� un par-feu ou autre mandataire re�oit les requ�tes et les fait suivre au serveur avec une adresse IP diff�rente, vous devez sp�cifier l'adresse IP de l'interface physique du serveur qui traite les requ�tes. Si vous avez plusieurs serveurs virtuels bas�s sur le nom avec plusieurs adresses, utilisez une directive pour chaque adresse.

Note

Notez que le "serveur principal" et tout serveur _default_ ne seront jamais sollicit�s pour une requ�te vers une adresse NameVirtualHost (� moins que pour une raison ou pour une autre, vous sp�cifiiez un NameVirtualHost sans d�finir de VirtualHosts pour cette adresse).

Vous pouvez �galement ajouter un num�ro de port sur lequel les serveurs virtuels bas�s sur le nom r�pondront, comme

NameVirtualHost 111.22.33.44:8080

Les adresses IPv6 doivent �tre entour�es de crochets, comme dans l'exemple suivant :

NameVirtualHost [2001:db8::a00:20ff:fea7:ccea]:8080

Pour recevoir les requ�tes sur toutes les interfaces, vous pouvez utiliser comme argument *:80, ou * dans le cas o� vous �coutez sur plusieurs ports et souhaitez vraiment que le serveur r�ponde sur chacun d'entre eux avec un jeu de serveurs virtuels particulier.

NameVirtualHost *:80

Argument de la directive <VirtualHost>

Notez que l'argument de la directive <VirtualHost> doit �tre identique � l'argument de la directive NameVirtualHost.

NameVirtualHost 1.2.3.4:80
<VirtualHost 1.2.3.4:80>
# ...
</VirtualHost>

Voir aussi

top

Options Directive

Description:D�finit les fonctionnalit�s disponibles pour un r�pertoire particulier
Syntaxe:Options [+|-]option [[+|-]option] ...
D�faut:Options All
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:Options
Statut:Core
Module:core

La directive Options permet de d�finir les fonctionnalit�s de serveur disponibles pour un r�pertoire particulier.

option peut �tre d�fini � None, auquel cas aucune fonctionnalit� sp�cifique n'est activ�e, ou comprendre une ou plusieurs des options suivantes :

All
Toutes les options except�e MultiViews. il s'agit de la configuration par d�faut.
ExecCGI
L'ex�cution de scripts CGI � l'aide du module mod_cgi est permise.
FollowSymLinks
Le serveur va suivre les liens symboliques dans le r�pertoire concern�.

Bien que le serveur suive les liens symboliques, il ne modifie pas le nom de chemin concern� d�fini par la section <Directory>.

Les options FollowSymLinks et SymLinksIfOwnerMatch ne fonctionnent que dans les sections <Directory> ou les fichiers .htaccess.

Le fait d'omettre cette option ne doit pas �tre consid�r� comme une mesure de s�curit� efficace, car il existe toujours une situation de comp�tition (race condition) entre l'instant o� l'on v�rifie qu'un chemin n'est pas un lien symbolique, et l'instant o� l'on utilise effectivement ce chemin.

Includes
Les inclusions c�t� serveur (SSI) � l'aide du module mod_include sont autoris�es.
IncludesNOEXEC
Les inclusions c�t� serveur (SSI) sont permises, mais #exec cmd et #exec cgi sont d�sactiv�es. L'utilisation de #include virtual pour les scripts CGI est cependant toujours possible depuis des r�pertoires d�finis par ScriptAlias.
Indexes
Si une URL requise correspond au r�pertoire concern�, et si aucun DirectoryIndex (par exemple index.html) n'est d�fini pour ce r�pertoire, le module mod_autoindex va renvoyer un listing format� du r�pertoire.
MultiViews
Les vues multiples ("multiviews") � contenu n�goci� � l'aide du module mod_negotiation sont autoris�es.
SymLinksIfOwnerMatch
Le serveur ne suivra que les liens symboliques qui renvoient vers un fichier ou un r�pertoire dont le propri�taire est le m�me que celui du lien.

Note

Les options FollowSymLinks et SymLinksIfOwnerMatch ne fonctionnent que dans les sections <Directory> ou les fichiers .htaccess.

Le fait d'omettre cette option ne doit pas �tre consid�r� comme une mesure de s�curit� efficace, car il existe toujours une situation de comp�tition (race condition) entre l'instant o� l'on v�rifie qu'un chemin n'est pas un lien symbolique, et l'instant o� l'on utilise effectivement ce chemin.

Normalement, si plusieurs directives Options peuvent s'appliquer � un r�pertoire, c'est la plus sp�cifique qui est utilis�e et les autres sont ignor�es ; les options ne sont pas fusionn�es (voir comment les sections sont fusionn�es). Elles le sont cependant si toutes les options de la directive Options sont pr�c�d�es d'un symbole + ou -. Toute option pr�c�d�e d'un + est ajout�e � la liste des options courantes de mani�re forc�e et toute option pr�c�d�e d'un - est supprim�e de la liste des options courantes de la m�me mani�re.

Avertissement

M�langer des Options avec + ou - avec des Options sans + ou - constitue une erreur de syntaxe, et peut r�sulter en des comportements inattendus.

Par exemple, sans aucun symbole + et - :

<Directory /web/docs>
Options Indexes FollowSymLinks
</Directory>

<Directory /web/docs/spec>
Options Includes
</Directory>

ici, seule l'option Includes sera prise en compte pour le r�pertoire /web/docs/spec. Par contre, si la seconde directive Options utilise les symboles + et - :

<Directory /web/docs>
Options Indexes FollowSymLinks
</Directory>

<Directory /web/docs/spec>
Options +Includes -Indexes
</Directory>

alors, les options FollowSymLinks et Includes seront prises en compte pour le r�pertoire /web/docs/spec.

Note

L'utilisation de -IncludesNOEXEC ou -Includes d�sactive compl�tement les inclusions c�t� serveur sans tenir compte des d�finitions pr�c�dentes.

En l'absence de toute d�finition d'options, la valeur par d�faut est All.

top

Protocol Directive

Description:Protocole pour une socket d'�coute
Syntaxe:Protocol protocole
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core
Compatibilit�:Disponible depuis la version 2.1.5 d'Apache, mais uniquement depuis la version 2.3.3 sous Windows.

Cette directive permet de sp�cifier le protocole utilis� pour une socket d'�coute particuli�re. Le protocole sert � d�terminer quel module doit traiter une requ�te, et d'appliquer les optimisations sp�cifiques au protocole via la directive AcceptFilter.

Vous ne devez d�finir le protocole que si vous travaillez avec des ports non standards ; dans le cas g�n�ral, le protocole http est associ� au port 80 et le protocole https au port 443.

Par exemple, si vous travaillez avec le protocole https sur un port non standard, sp�cifiez le protocole de mani�re explicite :

Protocol https

Vous pouvez aussi sp�cifier le protocole via la directive Listen.

Voir aussi

top

Require Directive

Description:D�termine les utilisateurs authentifi�s autoris�s � acc�der � une ressource
Syntaxe:Require nom entit� [nom entit�] ...
Contexte:r�pertoire, .htaccess
AllowOverride:AuthConfig
Statut:Core
Module:core

Cette directive permet de d�terminer les utilisateurs authentifi�s autoris�s � acc�der � une ressource. De multiples instances de cette directive se combinent entre elles avec un "OU" logique, si bien qu'un utilisateur qui convient � une ligne Require re�oit l'autorisation d'acc�s. Les restrictions sont trait�es par les modules d'autorisation. Voici quelques exemples de syntaxes autoris�es par mod_authz_user et mod_authz_groupfile :

Require user identifiant_utilisateur [identifiant_utilisateur] ...
Seuls les utilisateurs sp�cifi�s peuvent acc�der � la ressource.
Require group nom_groupe [nom_groupe] ...
Seuls les utilisateurs appartenant aux groupes sp�cifi�s peuvent acc�der � la ressource.
Require valid-user
Tout utilisateur valide peut acc�der � la ressource.

D'autres modules d'autorisation comme mod_authnz_ldap, mod_authz_dbm, et mod_authz_owner impl�mentent les options de la directive Require.

La directive Require doit �tre associ�e aux directives AuthName et AuthType, ainsi qu'� des directives telles que AuthUserFile et AuthGroupFile (pour la d�finition des utilisateurs et des groupes) afin de pouvoir fonctionner correctement. Exemple :

AuthType Basic
AuthName "Ressource � acc�s restreint"
AuthUserFile /web/users
AuthGroupFile /web/groups
Require group admin

Les contr�les d'acc�s appliqu�s de cette mani�re sont effectifs pour toutes les m�thodes HTTP. C'est en g�n�ral ce que l'on souhaite. Si vous d�sirez n'appliquer les contr�les d'acc�s que pour certaines m�thodes, tout en laissant les autres m�thodes sans protection, vous devez placer la directive Require � l'int�rieur d'une section <Limit>.

Si la directive Require est utilis�e conjointement avec les directives Allow ou Deny, l'interaction entre les diff�rentes restrictions impos�es est contr�l�e par la directive Satisfy.

D�sactivation des contr�les d'acc�s pour certains sous-r�pertoires

L'exemple suivant montre comment utiliser la directive Satisfy pour d�sactiver les contr�les d'acc�s dans un sous-r�pertoire d'un r�pertoire prot�g�. Cette technique doit �tre utilis�e avec pr�cautions, car elle va aussi d�sactiver tout contr�le d'acc�s impos� par mod_authz_host.

<Directory /chemin/vers/prot�g�/>
Require user david
</Directory>
<Directory /chemin/vers/prot�g�/non-prot�g�>
# Tous les contr�le d'acc�s et authentifications sont # d�sactiv�s pour ce r�pertoire
Satisfy Any
Allow from all
</Directory>

Voir aussi

top

RLimitCPU Directive

Description:Limite le temps CPU allou� aux processus initi�s par les processus enfants d'Apache
Syntaxe:RLimitCPU secondes|max [secondes|max]
D�faut:Non d�fini ; utilise les valeurs par d�faut du syst�me d'exploitation
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:All
Statut:Core
Module:core

Prend 1 ou 2 param�tres. Le premier definit la limite de consommation de ressources pour tous les processus, et le second la consommation de ressources maximale. Les deux param�tres peuvent contenir soit un nombre, soit max pour indiquer au serveur que la limite de consommation correspond � la valeur maximale autoris�e par la configuration du syst�me d'exploitation. Pour augmenter la consommation maximale de ressources, le serveur doit s'ex�cuter en tant que root, ou se trouver dans sa phase de d�marrage.

Cette directive s'applique aux processus initi�s par les processus enfants d'Apache qui traitent les requ�tes, et non aux processus enfants eux-m�mes. Sont concern�s les scripts CGI et les commandes exec des SSI, mais en aucun cas les processus initi�s par le processus parent d'Apache comme les journalisations redirig�es vers un programme.

Les limites de ressources CPU sont exprim�es en secondes par processus.

Voir aussi

top

RLimitMEM Directive

Description:Limite la m�moire allou�e aux processus initi�s par les processus enfants d'Apache
Syntaxe:RLimitMEM octets|max [octets|max]
D�faut:Non d�fini ; utilise les valeurs par d�faut du syst�me d'exploitation
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:All
Statut:Core
Module:core

Prend 1 ou 2 param�tres. Le premier definit la limite de consommation de ressources pour tous les processus, et le second la consommation de ressources maximale. Les deux param�tres peuvent contenir soit un nombre, soit max pour indiquer au serveur que la limite de consommation correspond � la valeur maximale autoris�e par la configuration du syst�me d'exploitation. Pour augmenter la consommation maximale de ressources, le serveur doit s'ex�cuter en tant que root, ou se trouver dans sa phase de d�marrage.

Cette directive s'applique aux processus initi�s par les processus enfants d'Apache qui traitent les requ�tes, et non aux processus enfants eux-m�mes. Sont concern�s les scripts CGI et les commandes exec des SSI, mais en aucun cas les processus initi�s par le processus parent d'Apache comme les journalisations redirig�es vers un programme.

Les limites de ressources m�moire sont exprim�es en octets par processus.

Voir aussi

top

RLimitNPROC Directive

Description:Limite le nombre de processus qui peuvent �tre initi�s par les processus initi�s par les processus enfants d'Apache
Syntaxe:RLimitNPROC nombre|max [nombre|max]
D�faut:Unset; uses operating system defaults
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:All
Statut:Core
Module:core

Prend 1 ou 2 param�tres. Le premier definit la limite de consommation de ressources pour tous les processus, et le second la consommation de ressources maximale. Les deux param�tres peuvent contenir soit un nombre, soit max pour indiquer au serveur que la limite de consommation correspond � la valeur maximale autoris�e par la configuration du syst�me d'exploitation. Pour augmenter la consommation maximale de ressources, le serveur doit s'ex�cuter en tant que root, ou se trouver dans sa phase de d�marrage.

Cette directive s'applique aux processus initi�s par les processus enfants d'Apache qui traitent les requ�tes, et non aux processus enfants eux-m�mes. Sont concern�s les scripts CGI et les commandes exec des SSI, mais en aucun cas les processus initi�s par le processus parent d'Apache comme les journalisations redirig�es vers un programme.

Les limites des processus contr�lent le nombre de processus par utilisateur.

Note

Si les processus CGI s'ex�cutent sous le m�me utilisateur que celui du serveur web, cette directive va limiter le nombre de processus que le serveur pourra lui-m�me cr�er. La pr�sence de messages cannot fork dans le journal des erreurs indiquera que la limite est atteinte.

Voir aussi

top

Satisfy Directive

Description:Interaction entre les contr�les d'acc�s par h�te et l'authentification des utilisateurs
Syntaxe:Satisfy Any|All
D�faut:Satisfy All
Contexte:r�pertoire, .htaccess
AllowOverride:AuthConfig
Statut:Core
Module:core
Compatibilit�:Influenc� par les sections <Limit> et <LimitExcept> dans les versions 2.0.51 et sup�rieures

Cette directive permet de d�finir la politique d'acc�s lorsque les directives Allow et Require sont utilis�es conjointement. L'argument prend pour valeur All ou Any. Cette directive ne s'av�re utile que dans le cas o� l'acc�s � une zone particuli�re est contr�l� � la fois par une authentification utilisateur/mot de passe et par l'adresse IP du client. Avec la valeur par d�faut de l'argument (All), le client doit d'abord satisfaire � la condition d'acc�s en fonction de son adresse IP, puis fournir un couple utilisateur/mot de passe valide. Si l'argument est Any, le client se verra accorder l'acc�s s'il satisfait � au moins une des conditions d'acc�s : adresse IP et/ou un couple utilisateur/mot de passe valides. On peut utiliser cette valeur pour restreindre l'acc�s � une zone � l'aide d'un mot de passe, mais laisser cette zone en acc�s libre pour les clients poss�dant certaines adresses IP.

Par exemple, si vous souhaitez accorder un acc�s sans restriction � une portion de votre site web aux clients de votre r�seau, mais n'accorder cet acc�s aux clients � l'ext�rieur de votre r�seau qu'en �change d'un mot de passe, vous pouvez utiliser une configuration de ce style :

Require valid-user
Order allow,deny
Allow from 192.168.1
Satisfy Any

Depuis la version 2.0.51, les directives Satisfy peuvent �tre limit�es � certaines m�thodes particuli�res � l'aide des sections <Limit> et <LimitExcept>.

Voir aussi

top

ScriptInterpreterSource Directive

Description:Permet de localiser l'interpr�teur des scripts CGI
Syntaxe:ScriptInterpreterSource Registry|Registry-Strict|Script
D�faut:ScriptInterpreterSource Script
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core
Compatibilit�:Win32 seulement ; l'option Registry-Strict est disponible dans les versions 2.0 et sup�rieures d'Apache

Cette directive permet de contr�ler la m�thode qu'utilise Apache pour trouver l'interpr�teur destin� � ex�cuter les scripts CGI. La d�finition par d�faut est Script : ceci indique � Apache qu'il doit utiliser l'interpr�teur pr�cis� dans la ligne shebang du script (la premi�re ligne, commen�ant par #!). Sur les syst�mes Win32, cette ligne ressemble souvent � ceci :

#!C:/Perl/bin/perl.exe

ou simplement, dans le cas o� perl est dans le PATH :

#!perl

Avec ScriptInterpreterSource Registry, Windows va effectuer une recherche dans l'arborescence HKEY_CLASSES_ROOT de la base de registre avec comme mot-cl� l'extension du fichier contenant le script (par exemple .pl). C'est la commande d�finie par la sous-cl� de registre Shell\ExecCGI\Command ou, si elle n'existe pas, la sous-cl� Shell\Open\Command qui est utilis�e pour ouvrir le fichier du script. Si ces cl�s de registre ne sont pas trouv�es, Apache utilise la m�thode de l'option Script.

Par exemple, pour que les scripts poss�dant l'extension .pl soient trait�s par perl, la ligne du registre doit �tre :

HKEY_CLASSES_ROOT\.pl\Shell\ExecCGI\Command\(Default) => C:\Perl\bin\perl.exe -wT

S�curit�

Soyez prudent si vous utilisez ScriptInterpreterSource Registry avec des r�pertoires faisant l'objet d'un ScriptAlias, car Apache va essayer d'ex�cuter tous les fichiers contenus dans celui-ci. L'option Registry peut causer des appels de programmes non voulus sur des fichiers non destin�s � �tre ex�cut�s. Par exemple, la commande par d�faut open sur les fichiers .htm sur la plupart des syst�mes Windows va lancer Microsoft Internet Explorer ; ainsi, toute requ�te HTTP pour un fichier .htm situ� dans le r�pertoire des scripts va lancer le navigateur en arri�re-plan sur le serveur, ce qui a toutes les chances de crasher votre syst�me dans les minutes qui suivent.

L'option Registry-Strict, apparue avec Apache 2.0, agit de mani�re identique � Registry, mais n'utilise que la sous-cl� Shell\ExecCGI\Command. La pr�sence de la cl� ExecCGI n'�tant pas syst�matique, Elle doit �tre d�finie manuellement dans le registre Windows et �vite ainsi tout appel de programme accidentel sur votre syst�me.

top

ServerAdmin Directive

Description:L'adresse �lectronique que le serveur inclut dans les messages d'erreur envoy�s au client
Syntaxe:ServerAdmin adresse �lectronique|URL
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

La directive ServerAdmin permet de d�finir l'adresse de contact que le serveur va inclure dans tout message d'erreur qu'il envoie au client. Si le programme httpd ne reconnait pas l'argument fourni comme une URL, il suppose que c'est une adresse �lectronique, et lui ajoute le pr�fixe mailto: dans les cibles des hyperliens. Il est cependant recommand� d'utiliser exclusivement une adresse �lectronique, car de nombreux scripts CGI consid�rent ceci comme implicite. Si vous utilisez une URL, elle doit pointer vers un autre serveur que vous contr�lez. Dans le cas contraire, les utilisateurs seraient dans l'impossibilit� de vous contacter en cas de probl�me.

Il peut s'av�rer utile de d�finir une adresse d�di�e � l'administration du serveur, par exemple :

ServerAdmin [email protected]

car les utilisateurs ne mentionnent pas syst�matiquement le serveur dont ils parlent !

top

ServerAlias Directive

Description:Autres noms d'un serveur utilisables pour atteindre des serveurs virtuels � base de nom
Syntaxe:ServerAlias nom serveur [nom serveur] ...
Contexte:serveur virtuel
Statut:Core
Module:core

La directive ServerAlias permet de d�finir les noms alternatifs d'un serveur utilisables pour atteindre des serveurs virtuels � base de nom. La directive ServerAlias peut contenir des caract�res g�n�riques, si n�cessaire.

<VirtualHost *:80>
ServerName serveur.domaine.com
ServerAlias serveur serveur2.domaine.com serveur2
ServerAlias *.example.com
UseCanonicalName Off
# ...
</VirtualHost>

La recherche du serveur virtuel � base de nom qui correspond le mieux s'effectue selon l'ordre d'apparition des sections <virtualhost> dans le fichier de configuration. Le premier serveur virtuel dont le ServerName ou le ServerAlias correspond est choisi, sans pr�f�rence si le nom contient des caract�res g�n�riques ou pas.

Tous les noms sp�cifi�s au sein d'une section VirtualHost sont trait�s comme un ServerAlias (sans caract�res g�n�riques).

Voir aussi

top

ServerName Directive

Description:Nom d'h�te et port que le serveur utilise pour s'authentifier lui-m�me
Syntaxe:ServerName [protocole://]nom de domaine enti�rement qualifi�[:port]
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core
Compatibilit�:Dans la version 2.0, cette directive remplace la fonctionnalit� de la directive Port de la version 1.3.

La directive ServerName permet de d�finir les protocole, nom d'h�te et port d'une requ�te que le serveur utilise pour s'authentifier lui-m�me. Ceci est utile lors de la cr�ation de redirections d'URLs.

La directive ServerName permet aussi (�ventuellement en conjonction avec la directive ServerAlias) d'identifier de mani�re unique un serveur virtuel, lorsqu'elle est utilis�e dans un contexte de serveurs virtuels par noms.

Par exemple, si le nom de la machine h�bergeant le serveur web est simple.example.com, la machine poss�de l'alias DNS www.example.com, et si vous voulez que le serveur web s'identifie avec cet alias, vous devez utilisez la d�finition suivante :

ServerName www.example.com

Si la directive ServerName n'est pas d�finie, le serveur tente de d�terminer le nom d'h�te en effectuant une recherche DNS inverse sur son adresse IP. Si la directive ServerName ne pr�cise pas de port, le serveur utilisera celui de la requ�te entrante. Il est recommand� de sp�cifier un nom d'h�te et un port sp�cifiques � l'aide de la directive ServerName pour une fiabilit� optimale et � titre pr�ventif.

Si vous d�finissez des serveurs virtuels � base de nom, une directive ServerName situ�e � l'int�rieur d'une section <VirtualHost> sp�cifiera quel nom d'h�te doit appara�tre dans l'en-t�te de requ�te Host: pour pouvoir atteindre ce serveur virtuel.

Parfois, le serveur s'ex�cute en amont d'un dispositif qui impl�mente SSL, comme un mandataire inverse, un r�partiteur de charge ou un bo�tier d�di� SSL. Dans ce cas, sp�cifiez le protocole https:// et le port auquel les clients se connectent dans la directive ServerName, afin de s'assurer que le serveur g�n�re correctement ses URLs d'auto-identification.

Voir la description des directives UseCanonicalName et UseCanonicalPhysicalPort pour les d�finitions qui permettent de d�terminer si les URLs auto-identifiantes (par exemple via le module mod_dir) vont faire r�f�rence au port sp�cifi�, ou au port indiqu� dans la requ�te du client.

Voir aussi

top

ServerPath Directive

Description:Nom de chemin d'URL h�rit� pour un serveur virtuel � base de nom acc�d� par un navigateur incompatible
Syntaxe:ServerPath chemin d'URL
Contexte:serveur virtuel
Statut:Core
Module:core

La directive ServerPath permet de d�finir le nom de chemin d'URL h�rit� d'un h�te, � utiliser avec les serveurs virtuels � base de nom.

Voir aussi

top

ServerRoot Directive

Description:Racine du r�pertoire d'installation du serveur
Syntaxe:ServerRoot chemin de r�pertoire
D�faut:ServerRoot /usr/local/apache
Contexte:configuration du serveur
Statut:Core
Module:core

La directive ServerRoot permet de d�finir le r�pertoire dans lequel le serveur est install�. En particulier, il contiendra les sous-r�pertoires conf/ et logs/. Les chemins relatifs indiqu�s dans les autres directives (comme Include ou LoadModule) seront d�finis par rapport � ce r�pertoire.

Example

ServerRoot /home/httpd

Voir aussi

top

ServerSignature Directive

Description:D�finit un pied de page pour les documents g�n�r�s par le serveur
Syntaxe:ServerSignature On|Off|EMail
D�faut:ServerSignature Off
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:All
Statut:Core
Module:core

La directive ServerSignature permet de d�finir une ligne de pied de page fixe pour les documents g�n�r�s par le serveur (messages d'erreur, listings de r�pertoires ftp de mod_proxy, sorties de mod_info, etc...). Dans le cas d'une cha�ne de mandataires, l'utilisateur n'a souvent aucun moyen de d�terminer lequel des mandataires cha�n�s a g�n�r� un message d'erreur, et c'est une des raisons pour lesquelles on peut �tre amen� � ajouter un tel pied de page.

La valeur par d�faut Off supprime la ligne de pied de page (et est ainsi compatible avec le comportement des versions 1.2 et ant�rieures d'Apache). la valeur On ajoute simplement une ligne contenant le num�ro de version du serveur ainsi que le nom du serveur virtuel issu de la directive ServerName, alors que la valeur EMail ajoute en plus une r�f�rence "mailto:" � l'administrateur du document r�f�renc� issu la directive ServerAdmin.

Depuis la version 2.0.44, les d�tails � propos du num�ro de version du serveur sont contr�l�s � l'aide de la directive ServerTokens.

Voir aussi

top

ServerTokens Directive

Description:Configure l'en-t�te Server de la r�ponse HTTP
Syntaxe:ServerTokens Major|Minor|Min[imal]|Prod[uctOnly]|OS|Full
D�faut:ServerTokens Full
Contexte:configuration du serveur
Statut:Core
Module:core

Cette directive permet de contr�ler le contenu de l'en-t�te Server inclus dans la r�ponse envoy�e au client : cet en-t�te peut contenir le type de syst�me d'exploitation du serveur, ainsi que des informations � propos des modules compil�s avec le serveur.

ServerTokens Prod[uctOnly]
Le serveur renvoie (par exemple): Server: Apache
ServerTokens Major
Le serveur renvoie (par exemple): Server: Apache/2
ServerTokens Minor
Le serveur renvoie (par exemple): Server: Apache/2.0
ServerTokens Min[imal]
Le serveur renvoie (par exemple): Server: Apache/2.0.41
ServerTokens OS
Le serveur renvoie (par exemple): Server: Apache/2.0.41 (Unix)
ServerTokens Full (valeur par d�faut)
Le serveur renvoie (par exemple): Server: Apache/2.0.41 (Unix) PHP/4.2.2 MyMod/1.2

Cette d�finition s'applique � l'ensemble du serveur et ne peut �tre activ�e ou d�sactiv�e pour tel ou tel serveur virtuel.

Dans les versions post�rieures � 2.0.44, cette directive contr�le �galement les informations fournies par la directive ServerSignature.

Voir aussi

top

SetHandler Directive

Description:Force le traitement des fichiers sp�cifi�s par un gestionnaire particulier
Syntaxe:SetHandler nom gestionnaire|None
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core
Compatibilit�:Int�gr� dans le noyau d'Apache depuis la version 2.0

Lorsqu'elle se situe � l'int�rieur d'un fichier .htaccess, ou d'une section <Directory> ou <Location>, cette directive force le traitement de tous les fichiers sp�cifi�s par le gestionnaire d�fini par l'argument nom gestionnaire. Par exemple, dans le cas d'un r�pertoire dont vous voulez interpr�ter le contenu comme des fichiers de r�gles d'images cliquables, sans tenir compte des extensions, vous pouvez ajouter la ligne suivante dans un fichier .htaccess de ce r�pertoire :

SetHandler imap-file

Autre exemple : si vous voulez que le serveur affiche un compte-rendu d'�tat chaque fois qu'une URL du type http://nom serveur/status est appel�e, vous pouvez ajouter ceci dans httpd.conf :

<Location /status>
SetHandler server-status
</Location>

Vous pouvez �craser la d�finition ant�rieure d'une directive SetHandler en utilisant la valeur None.

Voir aussi

top

SetInputFilter Directive

Description:D�finit les filtres par lesquels vont passer les requ�tes client et les donn�es POST
Syntaxe:SetInputFilter filtre[;filtre...]
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core

La directive SetInputFilter permet de d�finir le ou les filtres par lesquels vont passer les requ�tes client et les donn�es POST au moment o� le serveur les re�oit. Cette d�finition vient en ajout � tout autre filtre d�fini en quelqu'endroit que ce soit, y compris via la directive AddInputFilter.

Si la directive comporte plusieurs filtres, ils doivent �tre s�par�s par des points-virgules, et sp�cifi�s selon l'ordre dans lequel vous souhaitez les voir agir sur les contenus.

Voir aussi

top

SetOutputFilter Directive

Description:D�finit les filtres par lesquels vont passer les r�ponses du serveur
Syntaxe:SetOutputFilter filtre[;filtre...]
Contexte:configuration du serveur, serveur virtuel, r�pertoire, .htaccess
AllowOverride:FileInfo
Statut:Core
Module:core

La directive SetOutputFilter permet de d�finir les filtres par lesquels vont passer les r�ponses du serveur avant d'�tre envoy�es au client. Cette d�finition vient en ajout � tout autre filtre d�fini en quelqu'endroit que ce soit, y compris via la directive AddOutputFilter.

Par exemple, la configuration suivante va traiter tous les fichiers du r�pertoire /www/data/ comme des inclusions c�t� serveur (SSI) :

<Directory /www/data/>
SetOutputFilter INCLUDES
</Directory>

Si la directive comporte plusieurs filtres, ils doivent �tre s�par�s par des points-virgules, et sp�cifi�s selon l'ordre dans lequel vous souhaitez les voir agir sur les contenus.

Voir aussi

top

Suexec Directive

Description:Active ou d�sactive la fonctionnalit� suEXEC
Syntaxe:Suexec On|Off
D�faut:On si le binaire suexec existe avec un mode et un propri�taire appropri�s, Off dans le cas contraire
Contexte:configuration du serveur
Statut:Core
Module:core
Compatibilit�:Disponible depuis la version 2.2.18 d'Apache httpd

Lorsque cette directive est d�finie � On, le d�marrage du serveur �chouera si le binaire suexec n'existe pas, ou poss�de un mode de fichier ou un propri�taire invalides.

Lorsque cette directive est d�finie � Off, la fonctionnalit� suEXEC est d�sactiv�e, m�me si le binaire suexec existe et poss�de un mode de fichier et un propri�taire valides.

top

TimeOut Directive

Description:Temps pendant lequel le serveur va attendre certains �v�nements avant de consid�rer qu'une requ�te a �chou�
Syntaxe:TimeOut secondes
D�faut:TimeOut 300
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core

La directive TimeOut permet de d�finir le temps maximum pendant lequel Apache va attendre des entr�es/sorties dans diverses circonstances :

  1. Lors de la lecture de donn�es en provenance du client, le temps maximum d'attente avant l'arriv�e d'un paquet TCP si le tampon de lecture est vide.
  2. Lors de l'envoi de donn�es vers le client, le temps maximum d'attente avant l'arriv�e de l'accus�-r�ception d'un paquet si le tampon d'envoi est plein.
  3. Avec mod_cgi, le temps maximum d'attente avant la sortie des donn�es d'un script CGI.
  4. Avec mod_ext_filter, le temps maximum d'attente avant la sortie des donn�es d'un processus de filtrage.
  5. Avec mod_proxy, la valeur du d�lai par d�faut si la directive ProxyTimeout n'a pas �t� d�finie.
top

TraceEnable Directive

Description:D�termine le comportement des requ�tes TRACE
Syntaxe:TraceEnable [on|off|extended]
D�faut:TraceEnable on
Contexte:configuration du serveur, serveur virtuel
Statut:Core
Module:core
Compatibilit�:Disponible dans les versions 1.3.34, 2.0.55 et sup�rieures d'Apache

Cette directive l'emporte sur le comportement de TRACE pour le noyau du serveur et mod_proxy. La d�finition par d�faut TraceEnable on permet des requ�tes TRACE selon la RFC 2616, qui interdit d'ajouter tout corps � la requ�te. La d�finition TraceEnable off indique au noyau du serveur et � mod_proxy de retourner un code d'erreur 405 (M�thode non autoris�e) au client.

En fait, et � des fins de test et de diagnostic seulement, on peut autoriser l'ajout d'un corps de requ�te � l'aide de la d�finition non standard TraceEnable extended. Le noyau du serveur (dans le cas d'un serveur d'origine) va limiter la taille du corps de requ�te � 64k (plus 8k pour les en-t�tes de fractionnement si Transfer-Encoding: chunked est utilis�). Le noyau du serveur va reproduire l'ensemble des en-t�tes, y compris les en-t�tes de fractionnement avec le corps de la r�ponse. Dans le cas d'un serveur mandataire, la taille du corps de requ�te n'est pas limit�e � 64k.

top

UseCanonicalName Directive

Description:D�finit la mani�re dont le serveur d�termine son propre nom et son port
Syntaxe:UseCanonicalName On|Off|DNS
D�faut:UseCanonicalName Off
Contexte:configuration du serveur, serveur virtuel, r�pertoire
Statut:Core
Module:core

Dans de nombreuses situations, Apache doit construire une URL auto-identifiante -- c'est � dire une URL qui fait r�f�rence au serveur lui-m�me. Avec UseCanonicalName On, Apache va utiliser le nom d'h�te et le port sp�cifi�s par la directive ServerName pour construire le nom canonique du serveur. Ce nom est utilis� dans toutes les URLs auto-identifiantes, et affect� aux variables SERVER_NAME et SERVER_PORT dans les programmes CGI.

Avec UseCanonicalName Off, Apache va construire ses URLs auto-identifiantes � l'aide du nom d'h�te et du port fournis par le client, si ce dernier en a fourni un (dans la n�gative, Apache utilisera le nom canonique, de la m�me mani�re que ci-dessus). Ces valeurs sont les m�mes que celles qui sont utilis�es pour impl�menter les serveurs virtuels par nom, et sont disponibles avec les m�mes clients. De m�me, les variables CGI SERVER_NAME et SERVER_PORT seront affect�es des valeurs fournies par le client.

Cette directive peut s'av�rer utile, par exemple, sur un serveur intranet auquel les utilisateurs se connectent en utilisant des noms courts tels que www. Si les utilisateurs tapent un nom court suivi d'une URL qui fait r�f�rence � un r�pertoire, comme http://www/splat, sans le slash terminal, vous remarquerez qu'Apache va les rediriger vers http://www.domain.com/splat/. Si vous avez activ� l'authentification, ceci va obliger l'utilisateur � s'authentifier deux fois (une premi�re fois pour www et une seconde fois pour www.domain.com -- voir la foire aux questions sur ce sujet pour plus d'informations). Par contre, si UseCanonicalName est d�finie � Off, Apache redirigera l'utilisateur vers http://www/splat/.

Pour l'h�bergement virtuel en masse par adresse IP, on utilise une troisi�me option, UseCanonicalName DNS, pour supporter les clients anciens qui ne fournissent pas d'en-t�te Host:. Apache effectue alors une recherche DNS inverse sur l'adresse IP du serveur auquel le client s'est connect� afin de construire ses URLs auto-identifiantes.

Avertissement

Les programmes CGI risquent d'�tre perturb�s par cette option s'ils tiennent compte de la variable SERVER_NAME. Le client est pratiquement libre de fournir la valeur qu'il veut comme nom d'h�te. Mais si le programme CGI n'utilise SERVER_NAME que pour construire des URLs auto-identifiantes, il ne devrait pas y avoir de probl�me.

Voir aussi

top

UseCanonicalPhysicalPort Directive

Description:D�finit la mani�re dont le serveur d�termine son propre nom et son port
Syntaxe:UseCanonicalPhysicalPort On|Off
D�faut:UseCanonicalPhysicalPort Off
Contexte:configuration du serveur, serveur virtuel, r�pertoire
Statut:Core
Module:core

Dans de nombreuses situations, Apache doit construire une URL auto-identifiante -- c'est � dire une URL qui fait r�f�rence au serveur lui-m�me. Avec UseCanonicalPhysicalPort On, Apache va fournir le num�ro de port physique r�el utilis� par la requ�te en tant que port potentiel, pour construire le port canonique afin que le serveur puisse alimenter la directive UseCanonicalName. Avec UseCanonicalPhysicalPort Off, Apache n'utilisera pas le num�ro de port physique r�el, mais au contraire se r�f�rera aux informations de configuration pour construire un num�ro de port valide.

Note

L'ordre dans lequel s'effectue la recherche du port est le suivant :

UseCanonicalName On

  • Port sp�cifi� par Servername
  • Port physique
  • Port par d�faut
UseCanonicalName Off | DNS
  • Port sp�cifi� dans l'en-t�te Host:
  • Port physique
  • Port sp�cifi� par Servername
  • Port par d�faut

Avec UseCanonicalPhysicalPort Off, on reprend l'ordre ci-dessus en supprimant "Port physique".

Voir aussi

top

<VirtualHost> Directive

Description:Contient des directives qui ne s'appliquent qu'� un nom d'h�te sp�cifique ou � une adresse IP
Syntaxe:<VirtualHost adresse IP[:port] [adresse IP[:port]] ...> ... </VirtualHost>
Contexte:configuration du serveur
Statut:Core
Module:core

Les balises <VirtualHost> et </VirtualHost> permettent de rassembler un groupe de directives qui ne s'appliquent qu'� un serveur virtuel particulier. Toute directive autoris�e dans un contexte de serveur virtuel peut �tre utilis�e. Lorsque le serveur re�oit un requ�te pour un document h�berg� par un serveur virtuel particulier, il applique les directives de configuration rassembl�es dans la section <VirtualHost>. adresse IP peut �tre :

Exemple

<VirtualHost 10.1.2.3:80>
ServerAdmin [email protected]
DocumentRoot /www/docs/host.example.com
ServerName host.example.com
ErrorLog logs/host.example.com-error_log
TransferLog logs/host.example.com-access_log
</VirtualHost>

Les adresses IPv6 doivent �tre entour�es de crochets car dans le cas contraire, un �ventuel port optionnel ne pourrait pas �tre d�termin�. Voici un exemple de serveur virtuel avec adresse IPv6 :

<VirtualHost [2001:db8::a00:20ff:fea7:ccea]:80>
ServerAdmin [email protected]
DocumentRoot /www/docs/host.example.com
ServerName host.example.com
ErrorLog logs/host.example.com-error_log
TransferLog logs/host.example.com-access_log
</VirtualHost>

Chaque serveur virtuel doit correspondre � une adresse IP, un port ou un nom d'h�te sp�cifique ; dans le premier cas, le serveur doit �tre configur� pour recevoir les paquets IP de plusieurs adresses (si le serveur n'a qu'une interface r�seau, on peut utiliser � cet effet la commande ifconfig alias -- si votre syst�me d'exploitation le permet).

Note

L'utilisation de la directive <VirtualHost> n'affecte en rien les adresses IP sur lesquelles Apache est en �coute. Vous devez vous assurer que les adresses des serveurs virtuels sont bien incluses dans la liste des adresses pr�cis�es par la directive Listen.

Avec l'h�bergement virtuel � base d'adresse IP, on peut utiliser le nom sp�cial _default_, auquel cas le serveur virtuel consid�r� interceptera toute adresse IP qui n'est pas explicitement associ�e � un autre serveur virtuel. En l'absence de serveur virtuel associ� � _default_, et si l'adresse IP demand�e ne correspond � aucun serveur virtuel, c'est la configuration du serveur "principal" qui sera utilis�e, c'est � dire l'ensemble des d�finitions situ�es en dehors de toute section VirtualHost (Notez cependant que toute adresse IP correspondant � une directive NameVirtualHost n'utilisera ni la configuration du serveur "principal", ni le serveur virtuel _default_. Voir la documentation de l'h�bergement virtuel par nom pour plus de d�tails).

Vous pouvez sp�cifier :port pour modifier le port du serveur virtuel. S'il n'est pas sp�cifi�, sa valeur par d�faut correspond � celle qui est d�finie par la derni�re directive Listen du serveur principal. Vous pouvez aussi sp�cifier :* pour accepter tous les ports associ�s � l'adresse du serveur virtuel (c'est une configuration recommand�e lorsqu'on utilise _default_).

Tout bloc <VirtualHost> doit comporter une directive ServerName. Dans le cas contraire, le serveur virtuel h�ritera de la valeur de la directive ServerName issue de la configuration du serveur principal.

S�curit�

Voir le document sur les conseils � propos de la s�curit� pour une description d�taill�e des raisons pour lesquelles la s�curit� de votre serveur pourrait �tre compromise, si le r�pertoire contenant les fichiers journaux est inscriptible par tout autre utilisateur que celui qui d�marre le serveur.

Voir aussi

Langues Disponibles:  de  |  en  |  fr  |  ja  |  tr 

top

Commentaires

Notice:
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 mailing lists.