1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
|
<?xml version="1.0"?>
<!DOCTYPE modulesynopsis SYSTEM "../style/modulesynopsis.dtd">
<?xml-stylesheet type="text/xsl" href="../style/manual.fr.xsl"?>
<!-- English Revision : 911498 -->
<!-- French translation : Lucien GENTIS -->
<!-- Reviewed by : Vincent Deffontaines -->
<!--
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->
<modulesynopsis metafile="mod_expires.xml.meta">
<name>mod_expires</name>
<description>Génération des en-têtes HTTP <code>Expires</code> et
<code>Cache-Control</code> en fonction de critères spécifiés par
l'utilisateur</description>
<status>Extension</status>
<sourcefile>mod_expires.c</sourcefile>
<identifier>expires_module</identifier>
<summary>
<p>Ce module permet de contrôler la définition de l'en-tête HTTP
<code>Expires</code> et la directive <code>max-age</code> de
l'en-tête HTTP <code>Cache-Control</code> dans les réponses du
serveur. La date d'expiration peut être définie soit par rapport à
la date de dernière modification du fichier source, soit
par rapport à l'heure d'accès du client.</p>
<p>Ces en-têtes HTTP permettent d'informer le client quant à la
validité et à la persistence du document. S'il est présent dans le
cache, et tant qu'il n'est pas arrivé à expiration, le document sera
servi à partir de ce dernier, plutôt qu'à partir du document source.
Après expiration, la copie du document dans le cache sera considérée
comme "expirée" et donc invalide, et une nouvelle copie devra être
obtenue à partir du document source.</p>
<p>Pour modifier les directives de contrôle du cache autres
que <code>max-age</code> (voir la <a
href="http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.9">RFC
2616 section 14.9</a>), vous pouvez utiliser la directive <directive
module="mod_headers">Header</directive>.</p>
</summary>
<section id="AltSyn"><title>Autre syntaxe de définition de
l'intervalle</title>
<p>Pour une syntaxe plus lisible, on peut aussi utiliser les
directives <directive
module="mod_expires">ExpiresDefault</directive> et <directive
module="mod_expires">ExpiresByType</directive> comme suit :</p>
<example>
ExpiresDefault "<base> [plus] {<num>
<type>}*"<br />
ExpiresByType type/encoding "<base> [plus]
{<num> <type>}*"
</example>
<p>où <base> peut être :</p>
<ul>
<li><code>access</code></li>
<li><code>now</code> (équivalent à
'<code>access</code>')</li>
<li><code>modification</code></li>
</ul>
<p>Le mot-clé <code>plus</code> est optionnel. <num> doit
correspondre à une valeur entière [compatible avec
<code>atoi()</code>], et <type> peut être choisi parmi :</p>
<ul>
<li><code>years</code></li>
<li><code>months</code></li>
<li><code>weeks</code></li>
<li><code>days</code></li>
<li><code>hours</code></li>
<li><code>minutes</code></li>
<li><code>seconds</code></li>
</ul>
<p>Par exemple, pour faire expirer par défaut les documents 1 mois
après leur accès, on peut utiliser une des directives suivantes :</p>
<example>
ExpiresDefault "access plus 1 month"<br />
ExpiresDefault "access plus 4 weeks"<br />
ExpiresDefault "access plus 30 days"
</example>
<p>La date d'expiration peut être définie plus précisément en
ajoutant plusieurs clauses'<num> <type>' :</p>
<example>
ExpiresByType text/html "access plus 1 month 15
days 2 hours"<br />
ExpiresByType image/gif "modification plus 5 hours 3
minutes"
</example>
<p>Notez que si vous utilisez une configuration basée sur la date de
modification, l'en-tête Expires ne sera pas ajouté à un contenu qui
ne provient pas directement d'un fichier sur disque ; et ceci tout
simplement parce que ce type de contenu ne possède pas de date de
modification.</p>
</section>
<directivesynopsis>
<name>ExpiresActive</name>
<description>Active la génération d'en-têtes
<code>Expires</code></description>
<syntax>ExpiresActive On|Off</syntax>
<default>ExpiresActive Off</default>
<contextlist><context>server config</context>
<context>virtual host</context><context>directory</context>
<context>.htaccess</context></contextlist>
<override>Indexes</override>
<usage>
<p>Cette directive permet d'activer ou de désactiver la génération
des en-têtes <code>Expires</code> et <code>Cache-Control</code> pour
les documents concernés ; en d'autres termes, si cette directive se
trouve dans un fichier <code>.htaccess</code>, par exemple, elle ne
s'applique qu'aux documents générés à partir du répertoire
considéré. Si elle est définie à <code>Off</code>, les en-têtes ne
seront générés pour aucun document du domaine considéré (sauf
surcharge de la configuration à un niveau inférieur, comme un
fichier <code>.htaccess</code> qui l'emporterait sur le fichier de
configuration du serveur). Si elle est définie à <code>On</code>,
les en-têtes seront ajoutés aux documents servis en fonction des
critères définis par les directives <directive
module="mod_expires">ExpiresByType</directive> et <directive
module="mod_expires">ExpiresDefault</directive> (<em>voir plus
loin</em>).</p>
<p>Notez que cette directive ne permet pas de garantir qu'un en-tête
<code>Expires</code> ou <code>Cache-Control</code> sera généré. Si
les critères ne sont pas respectés, aucun en-tête ne sera généré, et
la directive produira le même effet que si elle n'avait pas été
définie.</p>
</usage>
</directivesynopsis>
<directivesynopsis>
<name>ExpiresByType</name>
<description>Définition de la valeur de l'en-tête <code>Expires</code>
en fonction du type MIME</description>
<syntax>ExpiresByType <var>type MIME</var>
<var><code>secondes</var></syntax>
<contextlist><context>server config</context><context>virtual host</context>
<context>directory</context><context>.htaccess</context></contextlist>
<override>Indexes</override>
<usage>
<p>Cette directive permet de définir la valeur de l'en-tête
<code>Expires</code> et de la directive <code>max-age</code> de
l'en-tête <code>Cache-Control</code> générés pour les documents du
type MIME spécifié (par exemple, <code>text/html</code>). Le second
argument définit le nombre de secondes qui seront ajoutées à un
temps de base pour calculer la date d'expiration.
<code>Cache-Control: max-age</code> se calcule en soustrayant la
date de la requête de la date d'expiration et s'exprime en
secondes.</p>
<p>Le champ <code><var><code></var></code> permet de spécifier
quel temps doit être utilisé comme temps de base; <code>M</code>
signifie que c'est la date
de dernière modification du fichier qui doit être utilisée comme
temps de base, alors que <code>A</code> signifie que c'est le moment
où le client a accédé au document qui doit être utilisé comme temps
de base.</p>
<p>La différence d'effet est subtile. Si on utilise <code>M</code>,
toutes les copies existantes du document dans tous les caches
expireront au même moment, ce qui peut convenir par exemple pour une
notice hebdomadaire qui correspond toujours à la même URL. Si on
utilise <code>A</code>, la date d'expiration sera différente pour
chaque client, ce qui peut convenir pour des fichiers d'images qui
ne changent pas très souvent, et en particulier pour un ensemble de
documents en relation qui se réfèrent tous aux mêmes images (ces
images sont alors accédées de manière répétitive dans un intervalle
de temps assez court).</p>
<example><title>Exemple :</title>
# active la génération des en-têtes Expires<br />
ExpiresActive On<br />
# les images GIF expirent au bout d'un mois dans le cache du
# client<br />
ExpiresByType image/gif A2592000<br />
# les documents HTML restent valables une semaine après leur date
# de dernière modification<br />
ExpiresByType text/html M604800
</example>
<p>Notez que cette directive ne produit d'effet que si
<code>ExpiresActive On</code> a été spécifié. Elle l'emporte, mais
<em>seulement</em> pour le type MIME spécifié, sur toute date
d'expiration définie par la directive <directive
module="mod_expires">ExpiresDefault</directive>.</p>
<p>Vous pouvez aussi définir le mode de calcul de la date
d'expiration en utilisant une <a href="#AltSyn">syntaxe
alternative</a>, comme décrit plus haut dans ce document.</p>
</usage>
</directivesynopsis>
<directivesynopsis>
<name>ExpiresDefault</name>
<description>Mode de calcul par défaut de la date
d'expiration</description>
<syntax>ExpiresDefault <var><code>secondes</var></syntax>
<contextlist><context>server config</context><context>virtual host</context>
<context>directory</context><context>.htaccess</context></contextlist>
<override>Indexes</override>
<usage>
<p>Cette directive permet de définir le mode de calcul par défaut de
la date d'expiration pour tous les documents du domaine considéré.
Elle peut être annulée pour certains types de documents par la
directive <directive
module="mod_expires">ExpiresByType</directive>. Voir la description
de cette dernière directive pour plus de détails à propos de la
syntaxe de l'argument, ainsi que la description de la <a
href="#AltSyn">syntaxe alternative</a>.</p>
</usage>
</directivesynopsis>
</modulesynopsis>
|