]> granicus.if.org Git - apache/blob - docs/manual/sections.html.ja.utf8
Update transformations.
[apache] / docs / manual / sections.html.ja.utf8
1 <?xml version="1.0" encoding="UTF-8"?>
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml" lang="ja" xml:lang="ja"><head><!--
4         XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
5               This file is generated from xml source: DO NOT EDIT
6         XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
7       -->
8 <title>セクションの設定 - Apache HTTP サーバ</title>
9 <link href="./style/css/manual.css" rel="stylesheet" media="all" type="text/css" title="Main stylesheet" />
10 <link href="./style/css/manual-loose-100pc.css" rel="alternate stylesheet" media="all" type="text/css" title="No Sidebar - Default font size" />
11 <link href="./style/css/manual-print.css" rel="stylesheet" media="print" type="text/css" />
12 <link href="./images/favicon.ico" rel="shortcut icon" /></head>
13 <body id="manual-page"><div id="page-header">
14 <p class="menu"><a href="./mod/">モジュール</a> | <a href="./mod/directives.html">ディレクティブ</a> | <a href="./faq/">FAQ</a> | <a href="./glossary.html">用語</a> | <a href="./sitemap.html">サイトマップ</a></p>
15 <p class="apache">Apache HTTP サーバ バージョン 2.3</p>
16 <img alt="" src="./images/feather.gif" /></div>
17 <div class="up"><a href="./"><img title="&lt;-" alt="&lt;-" src="./images/left.gif" /></a></div>
18 <div id="path">
19 <a href="http://www.apache.org/">Apache</a> &gt; <a href="http://httpd.apache.org/">HTTP サーバ</a> &gt; <a href="http://httpd.apache.org/docs/">ドキュメンテーション</a> &gt; <a href="./">バージョン
20             2.3</a></div><div id="page-content"><div id="preamble"><h1>セクションの設定</h1>
21 <div class="toplang">
22 <p><span>言語: </span><a href="./en/sections.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
23 <a href="./fr/sections.html" hreflang="fr" rel="alternate" title="Français">&nbsp;fr&nbsp;</a> |
24 <a href="./ja/sections.html" title="Japanese">&nbsp;ja&nbsp;</a> |
25 <a href="./ko/sections.html" hreflang="ko" rel="alternate" title="Korean">&nbsp;ko&nbsp;</a> |
26 <a href="./tr/sections.html" hreflang="tr" rel="alternate" title="Türkçe">&nbsp;tr&nbsp;</a></p>
27 </div>
28  <p><a href="configuring.html">設定ファイル</a>中のディレクティブは
29 サーバ全体に適用されたり、特定のディレクトリやファイル、ホスト、URL にのみ
30 適用されるように制限したりすることができます。この文書は設定用のセクションの
31 コンテナや <code>.htaccess</code> ファイルを使って他の設定ディレクティブの
32 スコープを変更する方法を説明します。</p>
33 </div>
34 <div id="quickview"><ul id="toc"><li><img alt="" src="./images/down.gif" /> <a href="#types">設定用セクションコンテナの種類</a></li>
35 <li><img alt="" src="./images/down.gif" /> <a href="#file-and-web">ファイルシステムとウェブ空間</a></li>
36 <li><img alt="" src="./images/down.gif" /> <a href="#virtualhost">バーチャルホスト</a></li>
37 <li><img alt="" src="./images/down.gif" /> <a href="#proxy">プロクシ</a></li>
38 <li><img alt="" src="./images/down.gif" /> <a href="#whatwhere">どのディレクティブが使えるの?</a></li>
39 <li><img alt="" src="./images/down.gif" /> <a href="#mergin">セクションのマージ方法</a></li>
40 </ul></div>
41 <div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
42 <div class="section">
43 <h2><a name="types" id="types">設定用セクションコンテナの種類</a></h2>
44
45 <table class="related"><tr><th>関連モジュール</th><th>関連ディレクティブ</th></tr><tr><td><ul><li><code class="module"><a href="./mod/core.html">core</a></code></li><li><code class="module"><a href="./mod/mod_version.html">mod_version</a></code></li><li><code class="module"><a href="./mod/mod_proxy.html">mod_proxy</a></code></li></ul></td><td><ul><li><code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code></li><li><code class="directive"><a href="./mod/core.html#directorymatch">&lt;DirectoryMatch&gt;</a></code></li><li><code class="directive"><a href="./mod/core.html#files">&lt;Files&gt;</a></code></li><li><code class="directive"><a href="./mod/core.html#filesmatch">&lt;FilesMatch&gt;</a></code></li><li><code class="directive"><a href="./mod/core.html#ifdefine">&lt;IfDefine&gt;</a></code></li><li><code class="directive"><a href="./mod/core.html#ifmodule">&lt;IfModule&gt;</a></code></li><li><code class="directive"><a href="./mod/mod_version.html#ifversion">&lt;IfVersion&gt;</a></code></li><li><code class="directive"><a href="./mod/core.html#location">&lt;Location&gt;</a></code></li><li><code class="directive"><a href="./mod/core.html#locationmatch">&lt;LocationMatch&gt;</a></code></li><li><code class="directive"><a href="./mod/mod_proxy.html#proxy">&lt;Proxy&gt;</a></code></li><li><code class="directive"><a href="./mod/mod_proxy.html#proxymatch">&lt;ProxyMatch&gt;</a></code></li><li><code class="directive"><a href="./mod/core.html#virtualhost">&lt;VirtualHost&gt;</a></code></li></ul></td></tr></table>
46
47 <p>コンテナには二つの基本となる種類があります。ほとんどのコンテナは
48 各リクエストに対して評価されます。その場合、コンテナ中のディレクティブは
49 コンテナにマッチするリクエストにのみ適用されます。一方、
50 <code class="directive"><a href="./mod/core.html#ifdefine">&lt;IfDefine&gt;</a></code>, 
51 <code class="directive"><a href="./mod/core.html#ifmodule">&lt;IfModule&gt;</a></code>, 
52 <code class="directive"><a href="./mod/mod_version.html#ifversion">&lt;IfVersion&gt;</a></code>
53 コンテナは
54 サーバの起動時と再起動時にのみ評価されます。起動時に条件が真であれば、
55 コンテナ中のディレクティブはすべてのリクエストに適用されます。条件が
56 偽であれば、コンテナ中のディレクティブは無視されます。</p>
57
58 <p><code class="directive"><a href="./mod/core.html#ifdefine">&lt;IfDefine&gt;</a></code> ディレクティブは
59 <code class="program"><a href="./programs/httpd.html">httpd</a></code> コマンドラインで適切なパラメータが定義されたときにのみ
60 適用されるディレクティブを囲います。例えば次の設定では、サーバが
61 <code>httpd -DClosedForNow</code> を使って起動されたときだけすべての
62 リクエストを別のサイトにリダイレクトします:</p>
63
64 <div class="example"><p><code>
65 &lt;IfDefine ClosedForNow&gt;<br />
66 Redirect / http://otherserver.example.com/<br />
67 &lt;/IfDefine&gt;
68 </code></p></div>
69
70 <p><code class="directive"><a href="./mod/core.html#ifmodule">&lt;IfModule&gt;</a></code> は
71 非常に似ていますが、代わりにサーバ上でモジュールが使用可能な場合にのみ
72 適用可能なディレクティブを囲います。モジュールはサーバに
73 静的に組み込まれているか、動的に組み込むようになっていて、設定ファイル中で
74 <code class="directive"><a href="./mod/mod_so.html#loadmodule">LoadModule</a></code> の行がより前の
75 部分に書かれている必要があります。このディレクティブは特定のモジュールの
76 存在に関わらず設定ファイルが動作する必要がある場合にのみ使ってください。
77 常に動作して欲しいディレクティブを囲むために使うべきではありません。
78 存在しないモジュールに関する有用なエラーメッセージの発生を抑制してしまいますので。
79 </p>
80
81 <p>次の例では、<code class="module"><a href="./mod/mod_mime_magic.html">mod_mime_magic</a></code> があるときにのみ <code class="directive"><a href="./mod/mod_mime_magic.html#mimemagicfiles">MimeMagicFiles</a></code> ディレクティブが
82 適用されます。</p>
83
84 <div class="example"><p><code>
85 &lt;IfModule mod_mime_magic.c&gt;<br />
86 MimeMagicFile conf/magic<br />
87 &lt;/IfModule&gt;
88 </code></p></div>
89
90 <p><code class="directive"><a href="./mod/mod_version.html#ifversion">&lt;IfVersion&gt;</a></code>
91 ディレクティブは
92 <code class="directive"><a href="./mod/core.html#ifdefine">&lt;IfDefine&gt;</a></code> や
93 <code class="directive"><a href="./mod/core.html#ifmodule">&lt;IfModule&gt;</a></code>と、
94 とてもよく似ていますが、稼働中のサーバのバージョンが特定のバージョンの時にのみ
95 適用されます。様々なバージョンの httpd を様々な設定で動作させることになる場合で、
96 テストスイートや巨大なネットワークでの用途を想定して、
97 このモジュールは設計されています。</p>
98
99 <div class="example"><p><code>
100   &lt;IfVersion &gt;= 2.1&gt;<br />
101   <span class="indent">
102     # this happens only in versions greater or<br />
103     # equal 2.1.0.<br />
104   </span>
105   &lt;/IfVersion&gt;
106 </code></p></div>
107
108 <p><code class="directive"><a href="./mod/core.html#ifdefine">&lt;IfDefine&gt;</a></code>, 
109 <code class="directive"><a href="./mod/core.html#ifmodule">&lt;IfModule&gt;</a></code>,
110 <code class="directive"><a href="./mod/mod_version.html#ifversion">&lt;IfVersion&gt;</a></code> ディレクティブは
111 テストの前に "!" を付けることで否定の条件を適用することができます。
112 また、これらのセクションはより複雑な制限を課すために入れ子にすることができます。
113 </p>
114 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
115 <div class="section">
116 <h2><a name="file-and-web" id="file-and-web">ファイルシステムとウェブ空間</a></h2>
117
118 <p>最もよく使われる設定のセクションコンテナはファイルシステムやウェブ空間の
119 特定の場所の設定を変更するものです。まず、この二つの違いを理解することが
120 大切です。ファイルシステムはオペレーティングシステムから見たディスクの内容です。
121 たとえば、デフォルトのインストールでは Apache は Unix ファイルシステムでは
122 <code>/usr/local/apache2</code> に、Windows ファイルシステムでは
123 <code>"c:/Program Files/Apache Group/Apache2"</code> に存在します。
124 (Apache では Windows でもパスセパレータとしてスラッシュを使うことに
125 気をつけてください。) 対照的に、ウェブ空間はあなたのサイトを
126 ウェブサーバから配信されるものとして見たもので、クライアントに見えるものです。
127 デフォルトの Unix 上の Apache のインストールではウェブ空間の
128 <code>/dir/</code> というパスはファイルシステムの
129 <code>/usr/local/apache2/htdocs/dir/</code> というパスに対応します。
130 ウェブページはデータベースや他の場所から動的に生成することもできますので、
131 ウェブ空間はファイルシステムに直接マップする必要はありません。</p>
132
133 <h3><a name="filesystem" id="filesystem">ファイルシステムコンテナ</a></h3>
134
135 <p><code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code> ディレクティブと
136 <code class="directive"><a href="./mod/core.html#files">&lt;Files&gt;</a></code> ディレクティブ、それと
137 それらの正規表現版はディレクティブをファイルシステムの一部分に対して適用します。
138 <code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code> セクションの
139 中のディレクティブは指定されたディレクトリとそのすべてのサブディレクトリに
140 適用されます。<a href="howto/htaccess.html">.htaccess ファイル</a>を
141 使うことでも同じ効果を得ることができます。例えば、次の設定では
142 <code>/var/web/dir1</code> とすべてのサブディレクトリに対して
143 ディレクトリインデックスを行ないます。</p>
144
145 <div class="example"><p><code>
146 &lt;Directory /var/web/dir1&gt;<br />
147 Options +Indexes<br />
148 &lt;/Directory&gt;
149 </code></p></div>
150
151 <p><code class="directive"><a href="./mod/core.html#files">&lt;Files&gt;</a></code> セクションの
152 中にあるディレクティブはどのディレクトリにあるかに関わらず、指定された名前の
153 すべてのファイルに適用されます。ですから例えば以下の設定ディレクティブが
154 設定ファイルの主セクションに書かれたときには、すべての場所の
155 <code>private.html</code> という名前のファイルへのアクセスを拒否します。</p>
156
157 <div class="example"><p><code>
158 &lt;Files private.html&gt;<br />
159 Order allow,deny<br />
160 Deny from all<br />
161 &lt;/Files&gt;
162 </code></p></div>
163
164 <p>ファイルシステムの特定の場所にあるファイルを指定するために、
165 <code class="directive"><a href="./mod/core.html#files">&lt;Files&gt;</a></code> セクションと
166 <code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code> セクションを
167 組み合わせることができます。例えば、次の設定では
168 <code>/var/web/dir1/private.html</code>, 
169 <code>/var/web/dir1/subdir2/private.html</code>, 
170 <code>/var/web/dir1/subdir3/private.html</code> など、
171 <code>/var/web/dir1/</code> ディレクトリの下にあるすべての
172 <code>private.html</code> へのアクセスを拒否します。</p>
173
174 <div class="example"><p><code>
175 &lt;Directory /var/web/dir1&gt;<br />
176 &lt;Files private.html&gt;<br />
177 Order allow,deny<br />
178 Deny from all<br />
179 &lt;/Files&gt;<br />
180 &lt;/Directory&gt;
181 </code></p></div>
182
183
184 <h3><a name="webspace" id="webspace">ウェブ空間コンテナ</a></h3>
185
186 <p>一方、<code class="directive"><a href="./mod/core.html#location">&lt;Location&gt;</a></code>
187 ディレクティブとその<a class="glossarylink" href="./glossary.html#regex" title="用語集を参照">正規表現</a>版は
188 ウェブ空間上の内容に対して設定を変更します。
189 たとえば、次の設定では /private で始まる URL パスへのアクセスを制限します。
190 具体的には、
191 <code>http://yoursite.example.com/private</code>,
192 <code>http://yoursite.example.com/private123</code>, 
193 <code>http://yoursite.example.com/private/dir/file.html</code> 
194 へのリクエストや、
195 他の同様に <code>/private</code> 文字列で始まるリクエストに
196 適用されます。</p>
197
198 <div class="example"><p><code>
199 &lt;Location /private&gt;<br />
200 Order Allow,Deny<br />
201 Deny from all<br />
202 &lt;/Location&gt;
203 </code></p></div>
204
205 <p><code class="directive"><a href="./mod/core.html#location">&lt;Location&gt;</a></code>
206 ディレクティブはファイルシステムと関係ある必要が全くありません。
207 たとえば次の例では、どのようにして特定の URL を
208 <code class="module"><a href="./mod/mod_status.html">mod_status</a></code>で提供されている Apache 
209 内部ハンドラにマップするかを示しています。ファイルシステムに
210 <code>server-status</code> というファイルが存在する必要はありません。</p>
211
212 <div class="example"><p><code>
213 &lt;Location /server-status&gt;<br />
214 SetHandler server-status<br />
215 &lt;/Location&gt;
216 </code></p></div>
217
218
219 <h3><a name="wildcards" id="wildcards">ワイルドカードと正規表現</a></h3>
220
221 <p><code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code>, 
222 <code class="directive"><a href="./mod/core.html#files">&lt;Files&gt;</a></code>, 
223 <code class="directive"><a href="./mod/core.html#location">&lt;Location&gt;</a></code> 
224 ディレクティブでは、 C 標準ライブラリの <code>fnmatch</code> のように
225 shell スタイルのワイルドカードキャラクタが使用できます。
226 "*" 文字は任意の文字列にマッチし、"?" 文字は任意の 1 文字にマッチし、
227 "[<em>seq</em>]" は <em>seq</em> の任意の文字にマッチします。
228 "/" 文字はどのワイルドカードでもマッチされません。
229 明示的に指定する必要があります。</p>
230
231 <p>これより柔軟なマッチングが必要な場合は、これらのコンテナに正規表現
232 (regex) 版である
233 <code class="directive"><a href="./mod/core.html#directorymatch">&lt;DirectoryMatch&gt;</a></code>, 
234 <code class="directive"><a href="./mod/core.html#filesmatch">&lt;FilesMatch&gt;</a></code>, 
235 <code class="directive"><a href="./mod/core.html#locationmatch">&lt;LocationMatch&gt;</a></code>
236 があり、マッチを選択するのに perl 互換<a class="glossarylink" href="./glossary.html#regex" title="用語集を参照">正規表現</a>を使用できます。しかし、次の設定のマージに目を通して、
237 regex セクションを使用することで、ディレクティブの適用がどのように
238 変化するか把握しておいてください。</p>
239
240 <p>全ユーザディレクトリの設定を変更する、非 regex
241 ワイルドカードセクションは次のようになります。</p>
242
243 <div class="example"><p><code>
244 &lt;Directory /home/*/public_html&gt;<br />
245 Options Indexes<br />
246 &lt;/Directory&gt;
247 </code></p></div>
248
249 <p>regex セクションを使用することで、画像ファイルの多くのタイプに対する
250 アクセスを一度に拒否できます。</p>
251 <div class="example"><p><code>
252 &lt;FilesMatch \.(?i:gif|jpe?g|png)$&gt;<br />
253 Order allow,deny<br />
254 Deny from all<br />
255 &lt;/FilesMatch&gt;
256 </code></p></div>
257
258
259
260 <h3><a name="whichwhen" id="whichwhen">いつ何を使うか</a></h3>
261
262 <p>ファイルシステムコンテナとウェブ空間コンテナを使い分けるのは、
263 実際には非常に簡単です。ファイルシステムに依存する
264 オブジェクトにディレクティブを適応する場合は、必ず
265 <code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code> か
266 <code class="directive"><a href="./mod/core.html#files">&lt;Files&gt;</a></code>
267 を使用します。ファイルシステムに依存しないオブジェクト
268 (データベースから生成されるウェブページなど) 
269 にディレクティブを適用する際には、
270 <code class="directive"><a href="./mod/core.html#location">&lt;Location&gt;</a></code>
271 を使用します。</p>
272
273 <p>ファイルシステム上のオブジェクトへのアクセスを制限するために、
274 <code class="directive"><a href="./mod/core.html#location">&lt;Location&gt;</a></code>
275 を決して使用ないようにしましょう。
276 同一のファイルシステム位置にマップしている、ウェブ空間位置 (URL)
277 が多数あって、設定した制限を迂回されてしまうかもしれないからです。
278 例えば次の設定を考えてみましょう。</p>
279
280 <div class="example"><p><code>
281 &lt;Location /dir/&gt;<br />
282 Order allow,deny<br />
283 Deny from all<br />
284 &lt;/Location&gt;
285 </code></p></div>
286
287 <p><code>http://yoursite.example.com/dir/</code>
288 へのリクエストでは上手く動作します。しかし大文字小文字を区別しない
289 ファイルシステムを使っていたらどうなるでしょう?
290 <code>http://yoursite.example.com/DIR/</code> 
291 へのリクエストで簡単にアクセス制限を迂回されてしまいます。これに対して
292 <code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code>
293 ディレクティブを使用すると、どのように呼び出されたかに関わらず
294 その場所から提供される内容に適用されます。
295 (例外はファイルシステムのリンクです。シンボリックリンクを使って、
296 同一のディレクトリを複数のファイルシステムに設置できます。
297 <code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code>
298 ディレクティブはパス名をリセットすることなくシンボリックリンクを
299 辿ります。ですから、高度なセキュリティが要求される場合は、
300 適切に <code class="directive"><a href="./mod/core.html#options">Options</a></code> 
301 ディレクティブを使用してシンボリックリンクを無効にするべきです。)</p>
302
303 <p>大文字小文字を区別するファイルシステムを使用しているから上記のことは
304 無関係だと思われるかもしれませんが、
305 同一のファイルシステム位置に複数のウェブ空間位置をマップする方法は、
306 他にいくらでもあるということを覚えていてください。
307 ですからできる限りファイルシステムコンテナを使用してください。
308 しかしながら一つだけ例外があります。
309 <code>&lt;Location /&gt;</code> セクションはどんな URL 
310 にも関わらず適用されるので、完全に安全です。</p>
311
312
313 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
314 <div class="section">
315 <h2><a name="virtualhost" id="virtualhost">バーチャルホスト</a></h2>
316
317 <p><code class="directive"><a href="./mod/core.html#virtualhost">&lt;VirtualHost&gt;</a></code>
318 コンテナは特定のホストに適用するディレクティブを格納します。
319 一台のマシンで複数のホストを異なる設定で提供したいときに有用です。
320 詳細に関しては<a href="vhosts/">バーチャルホストドキュメント</a>を
321 ご覧下さい。</p>
322 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
323 <div class="section">
324 <h2><a name="proxy" id="proxy">プロクシ</a></h2>
325
326 <p><code class="directive"><a href="./mod/mod_proxy.html#proxy">&lt;Proxy&gt;</a></code>
327 と <code class="directive"><a href="./mod/mod_proxy.html#proxymatch">&lt;ProxyMatch&gt;</a></code>
328 コンテナは、特定の URL にマッチする <code class="module"><a href="./mod/mod_proxy.html">mod_proxy</a></code>
329 プロクシサーバを経由してアクセスしたサイトに対してのみ適用される
330 設定ディレクティブを格納します。例えば次の設定は、<code>cnn.com</code> 
331 ウェブサイトにアクセスするために用いられるプロクシサーバを
332 制限します。</p>
333
334 <div class="example"><p><code>
335 &lt;Proxy http://cnn.com/*&gt;<br />
336 Order allow,deny<br />
337 Deny from all<br />
338 &lt;/Proxy&gt;
339 </code></p></div>
340 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
341 <div class="section">
342 <h2><a name="whatwhere" id="whatwhere">どのディレクティブが使えるの?</a></h2>
343
344 <p>どのタイプの設定セクションでどのディレクティブが使用できるかは、
345 ディレクティブの <a href="mod/directive-dict.html#Context">Context</a>
346 を見てください。
347 <code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code>
348 で使用可能なものは全て、同様に
349 <code class="directive"><a href="./mod/core.html#directorymatch">&lt;DirectoryMatch&gt;</a></code>,
350 <code class="directive"><a href="./mod/core.html#files">&lt;Files&gt;</a></code>,
351 <code class="directive"><a href="./mod/core.html#filesmatch">&lt;FilesMatch&gt;</a></code>,
352 <code class="directive"><a href="./mod/core.html#location">&lt;Location&gt;</a></code>,
353 <code class="directive"><a href="./mod/core.html#locationmatch">&lt;LocationMatch&gt;</a></code>,
354 <code class="directive"><a href="./mod/mod_proxy.html#proxy">&lt;Proxy&gt;</a></code>,
355 <code class="directive"><a href="./mod/mod_proxy.html#proxymatch">&lt;ProxyMatch&gt;</a></code>
356 セクションで使用可能です。しかしながら幾つか例外も存在します。</p>
357
358 <ul>
359 <li><code class="directive"><a href="./mod/core.html#allowoverride">AllowOverride</a></code> ディレクティブは
360 <code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code>
361 セクションでのみ使用可能です。</li>
362
363 <li><code>FollowSymLinks</code> と <code>SymLinksIfOwnerMatch</code> の
364 <code class="directive"><a href="./mod/core.html#options">Options</a></code> は、
365 <code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code>
366 セクションか <code>.htaccess</code> ファイルでのみ使用可能です。</li>
367
368 <li><code class="directive"><a href="./mod/core.html#options">Options</a></code> ディレクティブは、
369 <code class="directive"><a href="./mod/core.html#files">&lt;Files&gt;</a></code>
370 と <code class="directive"><a href="./mod/core.html#filesmatch">&lt;FilesMatch&gt;</a></code>
371 セクションでは使用できません。</li>
372 </ul>
373 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
374 <div class="section">
375 <h2><a name="mergin" id="mergin">セクションのマージ方法</a></h2>
376
377     <p>マージの順番は以下のようになっています:</p>
378
379     <ol>
380       <li><code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code> (正規表現無し) と
381       <code>.htaccess</code> を同時に (<code>.htaccess</code> が許可されていれば、それが
382       <code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code> を上書きします)
383       </li>
384
385       <li><code class="directive"><a href="./mod/core.html#directorymatch">&lt;DirectoryMatch&gt;</a></code>
386       (と <code>&lt;Directory ~&gt;</code></li>
387
388       <li><code class="directive"><a href="./mod/core.html#files">&lt;Files&gt;</a></code> と
389       <code class="directive"><a href="./mod/core.html#filesmatch">&lt;FilesMatch&gt;</a></code> を同時に</li>
390
391       <li><code class="directive"><a href="./mod/core.html#location">&lt;Location&gt;</a></code> と
392       <code class="directive"><a href="./mod/core.html#locationmatch">&lt;LocationMatch&gt;</a></code> を同時に</li>
393     </ol>
394
395     <p><code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code>
396     以外は、それぞれのグループは設定ファイルに現れた順番に処理されます。
397     <code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code> (上のグループ 1)
398     はディレクトリが短いものから長いものへと処理されます。ですから、
399     例えば <code>&lt;Directory /var/web/dir1&gt;</code> は
400     <code>&lt;Directory /var/web/dir/subdir&gt;</code> の前に処理されます。複数の
401     <code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code> セクションが
402     同じディレクトリに
403     適用される場合は、設定ファイル中の順番に従って処理されます。
404     <code class="directive"><a href="./mod/core.html#include">Include</a></code>
405     によって挿入された設定は 挿入しているファイルの
406     <code class="directive"><a href="./mod/core.html#include">Include</a></code>
407     ディレクティブの位置にあったかのように扱われます。</p>
408
409     <p><code class="directive"><a href="./mod/core.html#virtualhost">&lt;VirtualHost&gt;</a></code> セクション中のセクションは
410     バーチャルホストの定義の外側の対応するセクションの
411     <em>後</em>に適用されます。これによりバーチャルホストが
412     メインのサーバ設定を上書きできるようなります。</p>
413
414     <p><code class="module"><a href="./mod/mod_proxy.html">mod_proxy</a></code> でリクエストが処理される場合は、
415     処理順番のうち、<code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code> コンテナの部分が
416     <code class="directive"><a href="./mod/mod_proxy.html#proxy">&lt;Proxy&gt;</a></code>
417     コンテナに取って代わられます。</p>
418
419     <p>後のセクションのディレクティブが前のセクションのものを上書きします。</p>
420
421
422 <div class="note"><h3>技術メモ</h3>
423       実際には、名前を変換する段階 (URL
424       をファイル名にマップするために <code>Alias</code> や
425       <code>DocumentRoot</code> が使用されるところ) の直前に
426       <code class="directive"><a href="./mod/core.html#location">&lt;Location&gt;</a></code>/<code class="directive"><a href="./mod/core.html#locationmatch">&lt;LocationMatch&gt;</a></code>
427       が行なわれます。
428       これらを適用した結果は変換が終わった後に完全に捨てられます。
429 </div>
430 <h3><a name="merge-examples" id="merge-examples">例</a></h3>
431
432 <p>次はマージの順番を示すための恣意的な例になっています。
433 リクエスト全てに適用されるとして、本例のディレクティブは
434 A &gt; B &gt; C &gt; D &gt; E の順番に適用されます。</p>
435
436 <div class="example"><p><code>
437 &lt;Location /&gt;<br />
438 E<br />
439 &lt;/Location&gt;<br />
440 <br />
441 &lt;Files f.html&gt;<br />
442 D<br />
443 &lt;/Files&gt;<br />
444 <br />
445 &lt;VirtualHost *&gt;<br />
446 &lt;Directory /a/b&gt;<br />
447 B<br />
448 &lt;/Directory&gt;<br />
449 &lt;/VirtualHost&gt;<br />
450 <br />
451 &lt;DirectoryMatch "^.*b$"&gt;<br />
452 C<br />
453 &lt;/DirectoryMatch&gt;<br />
454 <br />
455 &lt;Directory /a/b&gt;<br />
456 A<br />
457 &lt;/Directory&gt;<br />
458 <br />
459 </code></p></div>
460
461 <p>もっと具体的な、次の例を考えてみましょう。
462 <code class="directive"><a href="./mod/core.html#directory">&lt;Directory&gt;</a></code> 
463 セクションに設置されたアクセス制限に関わらず、
464 <code class="directive"><a href="./mod/core.html#location">&lt;Location&gt;</a></code>
465 セクションが最後に評価されて、サーバへのアクセスは制限されません。
466 言い換えれば、マージの順番は重要で、注意して使用してください!</p>
467
468 <div class="example"><p><code>
469 &lt;Location /&gt;<br />
470 Order deny,allow<br />
471 Allow from all<br />
472 &lt;/Location&gt;<br />
473 <br />
474 # Woops!  This &lt;Directory&gt; section will have no effect<br />
475 &lt;Directory /&gt;<br />
476 Order allow,deny<br />
477 Allow from all<br />
478 Deny from badguy.example.com<br />
479 &lt;/Directory&gt;
480 </code></p></div>
481
482
483
484 </div></div>
485 <div class="bottomlang">
486 <p><span>言語: </span><a href="./en/sections.html" hreflang="en" rel="alternate" title="English">&nbsp;en&nbsp;</a> |
487 <a href="./fr/sections.html" hreflang="fr" rel="alternate" title="Français">&nbsp;fr&nbsp;</a> |
488 <a href="./ja/sections.html" title="Japanese">&nbsp;ja&nbsp;</a> |
489 <a href="./ko/sections.html" hreflang="ko" rel="alternate" title="Korean">&nbsp;ko&nbsp;</a> |
490 <a href="./tr/sections.html" hreflang="tr" rel="alternate" title="Türkçe">&nbsp;tr&nbsp;</a></p>
491 </div><div id="footer">
492 <p class="apache">Copyright 2010 The Apache Software Foundation.<br />Licensed under the <a href="http://www.apache.org/licenses/LICENSE-2.0">Apache License, Version 2.0</a>.</p>
493 <p class="menu"><a href="./mod/">モジュール</a> | <a href="./mod/directives.html">ディレクティブ</a> | <a href="./faq/">FAQ</a> | <a href="./glossary.html">用語</a> | <a href="./sitemap.html">サイトマップ</a></p></div>
494 </body></html>