blob: 7ac8bded06cef52946c2c6fbc44fb3b0d7090459 (
plain)
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
|
<?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: 420990:1515413 (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_negotiation.xml.meta">
<name>mod_negotiation</name>
<description><a href="../content-negotiation.html">コンテントネゴシエーション</a>
機能を提供する</description>
<status>Base</status>
<sourcefile>mod_negotiation.c</sourcefile>
<identifier>negotiation_module</identifier>
<summary>
<p>コンテントネゴシエーション、より正確にはコンテンツの選択機能は、
複数用意されているドキュメントから、クライアントの能力に一番合った
ドキュメントを選択する機能です。この実装は二つあります。</p>
<ul>
<li>タイプマップ (<code>type-map</code>
ハンドラで扱われるファイル)。これは variants
を含んでいるファイルを明示的に指定します。</li>
<li>MultiViews の探索 (<code>MultiViews</code> <directive
module="core">Option</directive> で有効になります)。
サーバが暗黙の内にファイル名のパターンマッチを行ない、
その結果から選択します。</li>
</ul>
</summary>
<seealso><directive module="core">Options</directive></seealso>
<seealso><module>mod_mime</module></seealso>
<seealso><a href="../content-negotiation.html">コンテントネゴシエーション</a></seealso>
<seealso><a href="../env.html">環境変数</a></seealso>
<section id="typemaps"><title>タイプマップ</title>
<p>タイプマップは RFC 822 のメールヘッダに類似した書式です。
ドキュメントの記述が空行で分離されて書かれていて、ハッシュ文字
('#') で始まる行はコメントとして扱われます。
ドキュメントの説明は複数のヘッダレコードから構成されます。
レコードは、続きの行が空白で始まっていると複数の行にまたがります。
最初の空白が消去されて、前の行とつなげて 1 行として扱われます。
ヘッダレコードはキーワード名の後に値が続くという形式で、
キーワード名は常にコロンで終わります。空白はヘッダ名と値の間、
値のトークンの間に入れることができます。
使用可能なヘッダは以下のとおりです:</p>
<dl>
<dt><code>Content-Encoding:</code></dt>
<dd>ファイルのエンコーディング。Apache は <directive
module="mod_mime">AddEncoding</directive> ディレクティブ
で定義されたエンコーディングだけを認識します。通常 compress
されたファイルのための <code>x-compress</code> と gzip
されたファイルのための <code>x-gzip</code> を含みます。
エンコーディングの比較をするときは、接頭辞 <code>x-</code>
は無視されます。</dd>
<dt><code>Content-Language:</code></dt>
<dd>インターネット標準の言語タグ
(<a href="http://www.ietf.org/rfc/rfc1766.txt">RFC 1766</a>)
で定義されている言語の種類。例えば、<code>en</code>
は英語を表します。
複数の言語が格納される場合はコンマで区切られます。</dd>
<dt><code>Content-Length:</code></dt>
<dd>ファイルの長さ (バイト数)。
このヘッダがない場合、ファイルの実際の長さが使用されます。</dd>
<dt><code>Content-Type:</code></dt>
<dd>ドキュメントの <glossary ref="mime-type">MIME
メディアタイプ</glossary>、オプショナルなパラメータ付き。パラメータの構文は
<code>name=value</code>
で、メディアタイプや他のパラメータとはセミコロンで分離されます。
共通のパラメータは以下のとおり:
<dl>
<dt><code>level</code></dt>
<dd>メディアタイプのバージョンを示す整数。
<code>text/html</code> では 2 がデフォルトで、その他の場合は
0 がデフォルトです。</dd>
<dt><code>qs</code></dt>
<dd>クライアントの能力に関係なく、variant
を他と比較したときの相対的な「品質」で、0.0 から 1.0
の範囲の浮動点小数。
例えば、写真を表現しようとしているときは普通は JPEG
ファイルの方が ASCII ファイルよりも高い品質になります。
しかし、リソースが ASCII アートで表現されているときは、ASCII
ファイルの方が JPEG
ファイルよりも高い品質になります。このように、<code>qs</code>
はリソース毎に特有の値を取ります。
</dd>
</dl>
<example><title>例</title>
Content-Type: image/jpeg; qs=0.8
</example>
</dd>
<dt><code>URI:</code></dt>
<dd>(指定のメディアタイプ、コンテントエンコーディングの) variant の
ファイルの uri. これは、マップファイルからの相対 URL として
解釈されます。同じサーバに存在しなければならず、クライアントが
直接リクエストしたときにアクセスを許可されるものでなければなりません。</dd>
<dt><code>Body:</code></dt>
<dd>Apache 2.0 で新設されたこの Body ヘッダを使って、
リソースの実際の内容をタイプマップファイルに書くことができます。
このヘッダは本文の内容の区切りとなる文字列で始まる必要があります。
タイプマップファイルの続く行は、区切り文字列が見つかるまで、
リソースの本文になります。
<example><title>Example:</title>
Body:----xyz----<br />
<html><br />
<body><br />
<p>Content of the page.</p><br />
</body><br />
</html><br />
----xyz----
</example>
</dd>
</dl>
</section>
<section id="multiviews"><title>MultiViews</title>
<p>MultiViews 探索は、<code>Multiviews</code> <directive
module="core">Options</directive> ディレクティブにより有効になります。
サーバが <code>/some/dir/foo</code>
へのリクエストを受け取り、<code>/some/dir/foo</code> が存在
<em>しない</em>場合、サーバはディレクトリを読んで、
<code>foo.*</code> にあてはまる全てのファイルを探し、
事実上それらのファイルをマップするタイプマップを作ります。
そのとき、メディアタイプとコンテントエンコーディングは、
そのファイル名を直接指定したときと同じものが割り当てられます。
それからクライアントの要求に一番合うものを選び、
そのドキュメントを返します。</p>
<p>ファイルを選択する際に、関連するコンテントネゴシエーションの
メタ情報を持たないファイルについて、判定を行うかどうかを
<directive module="mod_mime">MultiViewsMatch</directive>
ディレクティブで設定します。</p>
</section>
<directivesynopsis>
<name>CacheNegotiatedDocs</name>
<description>コンテントネゴシエーションされたドキュメントをプロキシサーバが
キャッシュできるようにする</description>
<syntax>CacheNegotiatedDocs On|Off</syntax>
<default>CacheNegotiatedDocs Off</default>
<contextlist><context>server config</context>
<context>virtual host</context>
</contextlist>
<compatibility>バージョン 2.0で構文が変わりました</compatibility>
<usage>
<p>このディレクティブが設定されていると、コンテントネゴシエーション
をした結果のドキュメントのキャッシュを許可します。
これは、プロキシの後ろにいるクライアントが能力に一番合った
ドキュメントではなく、
キャッシュをより効果的にするものを得る可能性があるということです。</p>
<p>このディレクティブは HTTP/1.0 ブラウザからのリクエスト
のみに適用されます。HTTP/1.1 は、
交渉されたドキュメントのキャッシュに対してずっとよい制御が可能なので、
このディレクティブは HTTP/1.1 のリクエストには影響しません。</p>
<p>2.0 より前のバージョンでは、
<directive>CacheNegotiatedDocs</directive> は引数を取らず、
ディレクティブが存在することで on の動作をしていました。</p>
</usage>
</directivesynopsis>
<directivesynopsis>
<name>ForceLanguagePriority</name>
<description>要求に合う単独のドキュメントが見つからなかったときに行なうことを指定
</description>
<syntax>ForceLanguagePriority None|Prefer|Fallback [Prefer|Fallback]</syntax>
<default>ForceLanguagePriority Prefer</default>
<contextlist><context>server config</context><context>virtual host</context>
<context>directory</context><context>.htaccess</context></contextlist>
<override>FileInfo</override>
<compatibility>バージョン 2.0.30 以降で使用可能</compatibility>
<usage>
<p><directive>ForceLanguagePriority</directive> ディレクティブは
要求に合うドキュメントを一つだけ返すことができないときに、
<directive module="mod_negotiation">LanguagePriority</directive>
ディレクティブを使ってネゴシエーションの結果を返します。</p>
<p><code>ForceLanguagePriority Prefer</code> は、同等の選択肢が
いくつかあるときに、HTTP の 300 (MULTIPLE CHOICES) を返す代わりに、
<code>LanguagePriority</code> を使って一つだけドキュメントを返すように
します。以下のディレクティブが指定されていて、ユーザの <code>Accept-Language</code>
ヘッダでは <code>en</code> と <code>de</code> の品質が共に
<code>.500</code> (同じくらい許容) であるときは、
最初にマッチする variant の <code>en</code> が送られます。</p>
<example>
LanguagePriority en fr de<br />
ForceLanguagePriority Prefer
</example>
<p><code>ForceLanguagePriority Fallback</code> では、HTTP 406
(NOT ACCEPTABLE) を送信する代わりに、
<directive module="mod_negotiation">LanguagePriority</directive>
が正しい結果を送ります。
以下のディレクティブが指定されていて、ユーザの <code>Accept-Language</code>
が <code>es</code> 言語のみを許可していて、さらにそのような variant がないときには、
以下の <directive module="mod_negotiation">LanguagePriority</directive>
のリストの最初の variant が送られます。</p>
<example>
LanguagePriority en fr de<br />
ForceLanguagePriority Fallback
</example>
<p><code>Prefer</code> と <code>Fallback</code> の両方のオプションを
同時に指定することができます。
ですから、複数の variant があるときは
<directive module="mod_negotiation">LanguagePriority</directive> の最初の
variant が送られ、クライアントの許容言語に合う vaiant がないときは
存在するドキュメントで最初のものが送られる、という様にすることができます。</p>
</usage>
<seealso><directive module="mod_mime">AddLanguage</directive></seealso>
</directivesynopsis>
<directivesynopsis>
<name>LanguagePriority</name>
<description>クライアントが優先度を示さなかったときの言語の variant の優先度を
指定</description>
<syntax>LanguagePriority <var>MIME-lang</var> [<var>MIME-lang</var>]
...</syntax>
<contextlist><context>server config</context><context>virtual host</context>
<context>directory</context><context>.htaccess</context></contextlist>
<override>FileInfo</override>
<usage>
<p><directive>LanguagePriority</directive> は、MultiViews
リクエストを扱うときに、クライアントが優先順位を提供していない場合の
言語の優先順位を設定します。<var>MIME-lang</var>
のリストが優先度の降順に並びます。</p>
<example><title>Example:</title>
LanguagePriority en fr de
</example>
<p><code>foo.html</code> がリクエストされ、<code>foo.html.fr</code>
と <code>foo.html.de</code> が両方存在し、
ブラウザが言語の優先順位を提供してない場合は
<code>foo.html.fr</code> が返されます。</p>
<p>このディレクティブは他の方法で「最善」
の言語が決定できないときか、<directive
module="mod_negotiation">ForceLanguagePriority</directive> ディレクティブが
<code>None</code> 以外のときにのみ効果があることに注意してください。
一般的には、サーバ側ではなくクライアント側で好みの言語を決定します。</p>
</usage>
<seealso><directive module="mod_mime">AddLanguage</directive></seealso>
</directivesynopsis>
</modulesynopsis>
|