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
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
|
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE modulesynopsis SYSTEM "../style/modulesynopsis.dtd">
<?xml-stylesheet type="text/xsl" href="../style/manual.ja.xsl"?>
<!-- English Revision: 151408:1197413 (outdated) -->
<!--
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_headers.xml.meta">
<name>mod_headers</name>
<description>HTTP リクエストのヘッダと応答のヘッダのカスタマイズ</description>
<status>Extension</status>
<sourcefile>mod_headers.c</sourcefile>
<identifier>headers_module</identifier>
<compatibility><directive module="mod_headers">RequestHeader</directive>
は Apache 2.0 以降のみで使用可能</compatibility>
<summary>
<p>このモジュールは HTTP のリクエストヘッダと応答ヘッダを制御し、
変更するためのディレクティブを提供します。ヘッダを追加したり、
置き換えたり、削除したりすることができます。</p>
</summary>
<section id="order"><title>処理の順番</title>
<p><module>mod_header</module> のディレクティブはサーバ設定のほぼどこにでも
書くことができ、影響する範囲を<a
href="../sections.html">設定用セクション</a>で囲むことで限定する
ことができます。</p>
<p>処理の順番は重要で、設定ファイル中の順番と、<a
href="../sections.html">設定用セクション</a>内の位置との両方に
影響されます。以下の二つのヘッダは順番が逆になると
違う結果になります:</p>
<example>
RequestHeader append MirrorID "mirror 12"<br />
RequestHeader unset MirrorID
</example>
<p>この順番の場合は、<code>MirrorID</code> ヘッダは設定されません。
逆になっていると、MirrorID ヘッダは "mirror 12" に設定されます。</p>
</section>
<section id="early"><title>早期処理、後期処理</title>
<p><module>mod_headers</module> では、リクエストの早期か後期かの
どちらで適用するかを選べます。通常は後期モードで、
コンテンツ生成が実行される直前にリクエストヘッダがセットされ、
レスポンスとして送出される直前にレスポンスヘッダがセットされます。
運用中のサーバでは必ず後期モードを使ってください。</p>
<p>早期モードは開発者向けのテスト/デバッグ用に設計されています。
<code>early</code> キーワード指定されたディレクティブによって、
リクエスト処理の開始地点になります。
つまり、異なるリクエストを試したりテストケースをセットアップするのに
活用できる一方で、レスポンスを生成する前に他のモジュールによって
ヘッダが書き換えられてしまうかもしれないということを意味します。</p>
<p>early ディレクティブではリクエストパスの設定が解決される前に
処理されるので、メインサーバかバーチャルホストコンテキストでのみ、
早期ヘッダをセットできます。early ディレクティブはリクエストパスに
依存することはできませんので、<code><Directory></code> や
<code><Location></code> といったコンテキスト内では使用
できません。</p>
</section>
<section id="examples"><title>例</title>
<ol>
<li>リクエストヘッダ中の "TS" で始まるフィールドをすべて応答ヘッダに
コピーします:
<example>
Header echo ^TS
</example>
</li>
<li>
リクエストを受け付けた時刻とリクエストを処理した時間を入れたヘッダ、
<code>MyHeader</code> を応答に追加します。このヘッダはクライアントが
サーバの負荷を直観的に知るためや、クライアント-サーバ間の
ボトルネックを調べるために使うことができます。
<example>
Header add MyHeader "%D %t"
</example>
<p>上記の設定では、以下のようなヘッダが応答に追加されることになります:</p>
<example>
MyHeader: D=3775428 t=991424704447256
</example>
</li>
<li>
Joe にあいさつをします:
<example>
Header add MyHeader "Hello Joe. It took %D microseconds for Apache to serve this request."
</example>
<p>以下のようなヘッダが応答に追加されることになります</p>
<example>
MyHeader: Hello Joe. It took D=3775428 microseconds for Apache to serve this request.
</example>
</li>
<li>リクエストに "MyRequestHeader" があるときに限り <code>MyHeader</code> を応答に
付けます。これは、クライアントの要求に応えてヘッダを作成するときに
役に立ちます。この例では <module>mod_setenvif</module> モジュールが必要なことに
注意してください。
<example>
SetEnvIf MyRequestHeader value HAVE_MyRequestHeader<br />
Header add MyHeader "%D %t mytext" env=HAVE_MyRequestHeader
</example>
<p>もし HTTP リクエストに <code>MyRequestHeader: value</code> ヘッダが
あると、応答には以下のようなヘッダが付加されます。</p>
<example>
MyHeader: D=3775428 t=991424704447256 mytext
</example>
</li>
</ol>
</section>
<directivesynopsis>
<name>RequestHeader</name>
<description>HTTP リクエストヘッダの設定</description>
<syntax>RequestHeader set|append|add|unset <var>header</var>
[<var>value</var>] [early|env=[!]<var>variable</var>]</syntax>
<contextlist><context>server config</context><context>virtual host</context>
<context>directory</context><context>.htaccess</context></contextlist>
<override>FileInfo</override>
<usage>
<p>このディレクティブは HTTP リクエストヘッダを置換、追加、削除できます。
ヘッダはコンテントハンドラが実行される直前に実行され、
入って来るヘッダを変更することが可能になっています。
行なう処理は第 1 引数により決まります。これには以下の値を指定
することができます:</p>
<dl>
<dt><code>set</code></dt>
<dd>リクエストヘッダを設定します。同じ名前のヘッダが存在していると、
それを置き換えます。</dd>
<dt><code>append</code></dt>
<dd>リクエストヘッダは、既に存在する同じ名前のヘッダに追加されます。
新しい値が既存のヘッダに追加されるときには、既存のヘッダの
後にコンマで区切られて追加されます。これはヘッダに複数の値を
指定するときの HTTP の標準の方法です。</dd>
<dt><code>add</code></dt>
<dd>ヘッダが既に存在しているときでさえも、リクエストヘッダを
既存のヘッダに追加します。これにより、二つ (かそれ以上) の
ヘッダの名前が同じになることがあります。その結果、想定できない
ことが起こる可能性がありますので、一般的には <code>append</code> の方を
使う方が良いでしょう。</dd>
<dt><code>unset</code></dt>
<dd>もし指定された名前のリクエストヘッダが存在していれば、削除されます。
同じ名前の複数のヘッダがあるときは、すべて削除されます。
<var>value</var> をつけてはいけません。</dd>
</dl>
<p>この引数の後にはヘッダ名 (<em>header</em>) が続きます。
ヘッダ名には最後にコロンを含めることもできますが、無くても構いません。
大文字小文字は区別されません。<code>add</code>,
<code>append</code>, <code>set</code> の場合は、<em>value</em> が三つ目の
引数として指定されます。<em>value</em> に空白がある場合は二重引用符で
囲む必要があります。unset の場合は、<em>value</em> は指定しません。
<var>value</var> は文字列、フォーマット指定子、あるいは、その混合です。
使うことのできるフォーマット指定子は、<directive
module="mod_headers">Header</directive> と同じですので、
詳細はそちらをご覧ください。</p>
<p><directive>RequestHeader</directive> ディレクティブは、
どういった条件下でアクションを行うかを指定する追加引数
あるいは、<a href="#early">早期処理</a> を指定する <code>early</code>
キーワードを設定することができます。
<code>env=<var>...</var></code> の引数で設定されている
<a href="../env.html">環境変数</a> が存在している
(あるいは <code>env=!<var>...</var></code> で指定された環境変数が
存在しない) 場合、<directive>RequestHeader</directive> ディレクティブは
有効になります。それ以外の場合、ディレクティブは効力を持ちません。</p>
<p><a href="#early">early</a> モードでない場合に限り、
<directive>RequestHeader</directive> ディレクティブは
fixup フェーズでリクエストがハンドラに扱われる直前に
処理されます。これにより、ブラウザや Apache の入力フィルタにより
生成されたヘッダを上書きしたり修正したりできるようになっています。</p>
</usage>
</directivesynopsis>
<directivesynopsis>
<name>Header</name>
<description>HTTP 応答ヘッダの設定</description>
<syntax>Header [<var>condition</var>] set|append|add|unset|echo
<var>header</var> [<var>value</var>] [early|env=[!]<var>variable</var>]</syntax>
<contextlist><context>server config</context><context>virtual host</context>
<context>directory</context><context>.htaccess</context></contextlist>
<override>FileInfo</override>
<usage>
<p>このディレクティブは HTTP 応答ヘッダを置換、追加、削除できます。
ヘッダはコンテントハンドラや出力フィルタが実行された直後に実行され、
出て行くヘッダを変更できるようになっています。</p>
<p>オプションの <var>condition</var> は <code>onsuccess</code> か
<code>always</code> のどちらかを指定できます。これは内部ヘッダテーブルのどれを
操作するかを決定します。<code>onsuccess</code> は <code>2<var>xx</var></code>
ステータスコードの、<code>always</code> は全てのステータスコード
(<code>2<var>xx</var></code> を含む) の意味になります。
あるモジュールでセットされるヘッダをアンセットしたい場合は特に、
どのテーブルが影響を受けるかを実際に試したほうがよいでしょう。</p>
<p>行なう処理は二番目のの引数で決まります。
この引数には次の値を指定できます:</p>
<dl>
<dt><code>set</code></dt>
<dd>応答ヘッダを設定します。同じ名前のヘッダが存在する場合はそれを
置き換えます。<em>value</em> にはフォーマット文字列を
指定することもできます。</dd>
<dt><code>append</code></dt>
<dd>応答ヘッダを既に存在する同じ名前のヘッダに追加します。
新しい値が既存のヘッダに追加されるときには、既存のヘッダの
後にコンマで区切られて追加されます。これはヘッダに複数の値を
指定するときの HTTP の標準の方法です。</dd>
<dt><code>add</code></dt>
<dd>ヘッダが既に存在しているときでさえも、応答ヘッダを
既存のヘッダに追加します。これにより、二つ (かそれ以上) の
ヘッダの名前が同じになることがあります。その結果、想定できない
ことが起こる可能性がありますので、一般的には <code>append</code> の方を
使う方が良いでしょう。</dd>
<dt><code>unset</code></dt>
<dd>もし指定された名前の応答ヘッダが存在していれば、削除されます。
同じ名前のヘッダが複数あるときは、すべて削除されます。
<var>value</var> をつけてはいけません。</dd>
<dt><code>echo</code></dt>
<dd>指定されたものと同じ名前のリクエストヘッダを応答ヘッダで
そのまま返します。<var>header</var> には正規表現も指定できます。
<var>value</var> をつけてはいけません。</dd>
</dl>
<p>この引数の後にはヘッダ名 (<var>header</var>) が続きます。
ヘッダ名には最後にコロンを含めることもできますが、無くても構いません。
<code>set</code>, <code>append</code>, <code>add</code>,
<code>unset</code> では大文字小文字は
区別されません。echo の <em>header</em> 名は大文字小文字を区別し、
正規表現を指定することもできます。</p>
<p><code>add</code>, <code>append</code>,
<code>set</code> では <var>value</var> を三つ目の
引数として指定します。<var>value</var> に空白がある場合は二重引用符で
囲む必要があります。<var>value</var> は文字のみからなる文字列、
フォーマット指示子を含む文字列、もしくは両方からなる文字列を指定できます。
<var>value</var> は以下のフォーマット指示子をサポートします:</p>
<table border="1" style="zebra">
<columnspec><column width=".25"/><column width=".75"/></columnspec>
<tr><th>フォーマット</th><th>解説</th></tr>
<tr><td><code>%%</code></td>
<td>パーセント記号</td></tr>
<tr><td><code>%t</code></td>
<td>リクエストを受け取った時刻を、
Universal Coordinated Time での始まりの時刻 (Jan. 1, 1970) から経過した
時間をマイクロ秒として現したもの。値の最初には
<code>t=</code> が付加されます。</td></tr>
<tr><td><code>%D</code></td>
<td>リクエストを受け取った時刻と、ヘッダを送り出した
時間との差。これは、リクエストが存在していた期間を現します。
値の最初には <code>D=</code> が付加されます。</td></tr>
<tr><td><code>%{FOOBAR}e</code></td>
<td><a href="../env.html">環境変数</a>
<code>FOOBAR</code> の値です。</td></tr>
<tr><td><code>%{FOOBAR}s</code></td>
<td><module>mod_ssl</module> が有効な場合、
<a href="mod_ssl.html#envvars">SSL 環境変数</a> <code>FOOBAR</code>
の内容</td></tr>
</table>
<note><title>注</title>
<p><code>%s</code> フォーマット指定子は 2.1 以降でのみ利用できます。
<code>SSLOptions +StdEnvVars</code> を有効にすることによるオーバーヘッドを
避けるため、<code>%e</code> の代わりとして使えます。
他の理由などがあって、どうしても <code>SSLOptions +StdEnvVars</code>
を有効にしなければならない場合は、<code>%e</code> のほうが
<code>%s</code> よりも処理効率は良いです。</p>
</note>
<p><directive>Header</directive> ディレクティブには追加の引数を持たせることが
できて、どういったアクションが行われたかの条件を指定したり、
<a href="#early">早期処理</a> を指定する <code>early</code> キーワードを
指定できます。
<code>env=...</code> 引数で指定された <a
href="../env.html">環境変数</a> が存在する (もしくは <code>env=!...</code>
が指定されていて環境変数が存在しない) 場合は、<directive>Header</directive>
ディレクティブで指定された動作が行なわれます。そうでない場合は、
ディレクティブはそのリクエストには何もしません。</p>
<p><a href="#early">早期処理</a>モードの場合以外では、
<directive>Header</directive>
ディレクティブは応答がネットワークに送られる直前に
処理されます。これは、ヘッダフィルタにより追加されるヘッダを
除き、ほとんどのヘッダを設定したり上書きしたりすることが
可能、ということです。</p>
</usage>
</directivesynopsis>
</modulesynopsis>
|