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
8 <title>URL からファイルシステム上の位置へのマップ - 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.0</p>
16 <img alt="" src="./images/feather.gif" /></div>
17 <div class="up"><a href="./"><img title="<-" alt="<-" src="./images/left.gif" /></a></div>
19 <a href="http://www.apache.org/">Apache</a> > <a href="http://httpd.apache.org/">HTTP サーバ</a> > <a href="http://httpd.apache.org/docs/">ドキュメンテーション</a> > <a href="./">バージョン 2.0</a></div><div id="page-content"><div id="preamble"><h1>URL からファイルシステム上の位置へのマップ</h1>
21 <p><span>Available Languages: </span><a href="./en/urlmapping.html" hreflang="en" rel="alternate" title="English"> en </a> |
22 <a href="./ja/urlmapping.html" title="Japanese"> ja </a> |
23 <a href="./ko/urlmapping.html" hreflang="ko" rel="alternate" title="Korean"> ko </a> |
24 <a href="./tr/urlmapping.html" hreflang="tr" rel="alternate" title="Türkçe"> tr </a></p>
27 <p>この文書は Apache がリクエストの URL から送信するファイルの
28 ファイルシステム上の位置を決定する方法を説明します。</p>
30 <div id="quickview"><ul id="toc"><li><img alt="" src="./images/down.gif" /> <a href="#related">関連するモジュールとディレクティブ</a></li>
31 <li><img alt="" src="./images/down.gif" /> <a href="#documentroot">DocumentRoot</a></li>
32 <li><img alt="" src="./images/down.gif" /> <a href="#outside">DocumentRoot 外のファイル</a></li>
33 <li><img alt="" src="./images/down.gif" /> <a href="#user">ユーザディレクトリ</a></li>
34 <li><img alt="" src="./images/down.gif" /> <a href="#redirect">URL リダイレクション</a></li>
35 <li><img alt="" src="./images/down.gif" /> <a href="#proxy">リバースプロキシ</a></li>
36 <li><img alt="" src="./images/down.gif" /> <a href="#rewrite">リライトエンジン</a></li>
37 <li><img alt="" src="./images/down.gif" /> <a href="#notfound">File Not Found</a></li>
39 <div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
41 <h2><a name="related" id="related">関連するモジュールとディレクティブ</a></h2>
43 <table class="related"><tr><th>関連モジュール</th><th>関連ディレクティブ</th></tr><tr><td><ul><li><code class="module"><a href="./mod/mod_alias.html">mod_alias</a></code></li><li><code class="module"><a href="./mod/mod_proxy.html">mod_proxy</a></code></li><li><code class="module"><a href="./mod/mod_rewrite.html">mod_rewrite</a></code></li><li><code class="module"><a href="./mod/mod_userdir.html">mod_userdir</a></code></li><li><code class="module"><a href="./mod/mod_speling.html">mod_speling</a></code></li><li><code class="module"><a href="./mod/mod_vhost_alias.html">mod_vhost_alias</a></code></li></ul></td><td><ul><li><code class="directive"><a href="./mod/mod_alias.html#alias">Alias</a></code></li><li><code class="directive"><a href="./mod/mod_alias.html#aliasmatch">AliasMatch</a></code></li><li><code class="directive"><a href="./mod/mod_speling.html#checkspelling">CheckSpelling</a></code></li><li><code class="directive"><a href="./mod/core.html#documentroot">DocumentRoot</a></code></li><li><code class="directive"><a href="./mod/core.html#errordocument">ErrorDocument</a></code></li><li><code class="directive"><a href="./mod/core.html#options">Options</a></code></li><li><code class="directive"><a href="./mod/mod_proxy.html#proxypass">ProxyPass</a></code></li><li><code class="directive"><a href="./mod/mod_proxy.html#proxypassreverse">ProxyPassReverse</a></code></li><li><code class="directive"><a href="./mod/mod_alias.html#redirect">Redirect</a></code></li><li><code class="directive"><a href="./mod/mod_alias.html#redirectmatch">RedirectMatch</a></code></li><li><code class="directive"><a href="./mod/mod_rewrite.html#rewritecond">RewriteCond</a></code></li><li><code class="directive"><a href="./mod/mod_rewrite.html#rewritematch">RewriteMatch</a></code></li><li><code class="directive"><a href="./mod/mod_alias.html#scriptalias">ScriptAlias</a></code></li><li><code class="directive"><a href="./mod/mod_alias.html#scriptaliasmatch">ScriptAliasMatch</a></code></li><li><code class="directive"><a href="./mod/mod_userdir.html#userdir">UserDir</a></code></li></ul></td></tr></table>
44 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
46 <h2><a name="documentroot" id="documentroot">DocumentRoot</a></h2>
48 <p>リクエストに対してどのファイルを送信するかを決定するときの
49 Apache のデフォルトの動作は、リクエストの URL-Path (URL のホスト名と
50 ポート番号の後に続く部分) を取り出して設定ファイルで指定されている
51 <code class="directive"><a href="./mod/core.html#documentroot">DocumentRoot</a></code>
52 の最後に追加する、というものです。ですから、
53 <code class="directive"><a href="./mod/core.html#documentroot">DocumentRoot</a></code>
54 の下のディレクトリやファイルがウェブから見える基本のドキュメントの木構造を
57 <p>Apache にはサーバが複数のホストへのリクエストを受け取る
58 <a href="vhosts/">バーチャルホスト</a> の機能もあります。
59 この場合、それぞれのバーチャルホストに対して違う
60 <code class="directive"><a href="./mod/core.html#documentroot">DocumentRoot</a></code>
61 を指定することができます。また、<code class="module"><a href="./mod/mod_vhost_alias.html">mod_vhost_alias</a></code>
62 モジュールにより提供されるディレクティブを使って、
63 送信するためのコンテンツの場所をリクエストされた IP
64 アドレスやホスト名から動的に決めることもできます。</p>
65 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
67 <h2><a name="outside" id="outside">DocumentRoot 外のファイル</a></h2>
70 厳密には <code class="directive"><a href="./mod/core.html#documentroot">DocumentRoot</a></code>
71 の下にはない部分へのウェブアクセスを許可する必要がある
72 場合がよくあります。Apache はこのために複数の方法を用意しています。
73 Unix システムでは、ファイルシステムの他の部分をシンボリックリンクを
74 使って <code class="directive"><a href="./mod/core.html#documentroot">DocumentRoot</a></code>
75 の下に持ってくることができます。セキュリティ上の理由により、
77 <code class="directive"><a href="./mod/core.html#options">Options</a></code> の設定に
78 <code>FollowSymLinks</code> か <code>SymLinksIfOwnerMatch</code> が
79 ある場合にのみシンボリックリンクをたどります。</p>
81 <p>代わりの方法として、<code class="directive"><a href="./mod/mod_alias.html#alias">Alias</a></code>
82 ディレクティブを使ってファイルシステムの任意の部分をウェブの空間に
85 <div class="example"><p><code>Alias /docs /var/web</code></p></div>
88 <code>http://www.example.com/docs/dir/file.html</code> には
89 <code>/var/web/dir/file.html</code> が送信されます。
90 <code class="directive"><a href="./mod/mod_alias.html#scriptalias">ScriptAlias</a></code> も、
91 対象となっているパスが CGI スクリプトとして扱われるという追加の
95 <code class="directive"><a href="./mod/mod_alias.html#aliasmatch">AliasMatch</a></code> ディレクティブや
96 <code class="directive"><a href="./mod/mod_alias.html#scriptaliasmatch">ScriptAliasMatch</a></code> ディレクティブ
97 を使って強力な正規表現に基づいたマッチと置換を行なうことができます。
100 <div class="example"><p><code>ScriptAliasMatch ^/~([a-zA-Z0-9]+)/cgi-bin/(.+)
101 /home/$1/cgi-bin/$2</code></p></div>
103 <p>は <code>http://example.com/~user/cgi-bin/script.cgi</code> への
104 リクエストを <code>/home/user/cgi-bin/script.cgi</code> というパスへ
105 マップし、このマップの結果としてのファイルを CGI スクリプトとして
107 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
108 <div class="section">
109 <h2><a name="user" id="user">ユーザディレクトリ</a></h2>
111 <p>伝統的に Unix システムではユーザ <em>user</em> のホームディレクトリを
112 <code>~user/</code> として参照できます。<code class="module"><a href="./mod/mod_userdir.html">mod_userdir</a></code>
114 それぞれのユーザのホームディレクトリのファイルを
115 以下のような URL を使ってアクセスできるようにします。</p>
117 <div class="example"><p><code>http://www.example.com/~user/file.html</code></p></div>
119 <p>セキュリティの観点から、ウェブからユーザのホームディレクトリへ
120 直接アクセスできるようにすることは適切ではありません。ですから、
121 <code class="directive"><a href="./mod/mod_userdir.html#userdir">UserDir</a></code> ディレクティブには
122 ユーザのホームディレクトリの下の、ウェブファイルの
123 置かれているディレクトリを指定します。デフォルトの設定の
124 <code>Userdir public_html</code> を使うと、上の URL は
125 <code>/home/user/public_html/file.html</code> というようなファイルに
126 マップされます。ここで、<code>/home/user/</code> は
127 <code>/etc/passwd</code> で指定されているユーザのホームディレクトリです。</p>
129 <p><code class="directive"><a href="./mod/mod_userdir.html#userdir">Userdir</a></code> には、
130 <code>/etc/passwd</code> にホームディレクトリの位置が書かれていない
131 システムでも使うことのできる他の形式もあります。</p>
133 <p>中にはシンボル "~" (<code>%7e</code> のように符号化されることが多い)
134 を格好が悪いと思って、ユーザのディレクトリを表すために別の文字列の
135 使用を好む人がいます。mod_userdir はこの機能をサポートしていません。
136 しかし、ユーザのホームディレクトリが規則的な構成のときは、
137 <code class="directive"><a href="./mod/mod_alias.html#aliasmatch">AliasMatch</a></code> を使って望みの
139 <code>http://www.example.com/upages/user/file.html</code> が
140 <code>/home/user/public_html/file.html</code> にマップされるようにするには、
141 以下のように <code>AliasMatch</code> ディレクティブを使います:</p>
143 <div class="example"><p><code>AliasMatch ^/upages/([a-zA-Z0-9]+)/?(.*)
144 /home/$1/public_html/$2</code></p></div>
145 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
146 <div class="section">
147 <h2><a name="redirect" id="redirect">URL リダイレクション</a></h2>
149 <p>上の節で説明した設定用のディレクティブは Apache に
150 ファイルシステムの特定の場所からコンテンツを取ってきて
151 クライアントに送り返すようにします。ときには、その代わりに
152 クライアントにリクエストされたコンテンツは別の URL にあることを
153 知らせて、クライアントが新しい URL へ新しいリクエストを行なうように
154 する方が望ましいことがあります。これは<em>リダイレクション</em>と
155 呼ばれていて、<code class="directive"><a href="./mod/mod_alias.html#redirect">Redirect</a></code>
156 ディレクティブにより実装されています。たとえば、
157 <code class="directive"><a href="./mod/core.html#documentroot">DocumentRoot</a></code> の下のディレクトリ
158 <code>/foo/</code> が新しいディレクトリ <code>/bar/</code> に移動したときは、
159 以下のようにしてクライアントが新しい場所のコンテンツをリクエストするように
162 <div class="example"><p><code>Redirect permanent /foo/
163 http://www.example.com/bar/</code></p></div>
165 <p>これは、<code>/foo/</code> で始まるすべての URL-Path を、
166 <code>www.example.com</code> サーバの <code>/bar/</code> が
167 <code>/foo/</code> に置換されたものにリダイレクトします。
168 サーバは自分自身のサーバだけでなく、どのサーバにでもクライアントを
171 <p>Apache はより複雑な書き換えの問題のために、
172 <code class="directive"><a href="./mod/mod_alias.html#redirectmatch">RedirectMatch</a></code> ディレクティブを
173 提供しています。たとえば、サイトのホームページを違うサイトにリダイレクト
174 するけれど、他のリクエストはそのまま扱う、というときは以下の設定を
177 <div class="example"><p><code>RedirectMatch permanent ^/$
178 http://www.example.com/startpage.html</code></p></div>
180 <p>あるいは、一時的にサイトのすべてのページを他のサイトの特定の
181 ページへリダイレクトするときは、以下を使います:</p>
183 <div class="example"><p><code>RedirectMatch temp .*
184 http://othersite.example.com/startpage.html</code></p></div>
185 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
186 <div class="section">
187 <h2><a name="proxy" id="proxy">リバースプロキシ</a></h2>
189 <p>Apache は遠隔地にあるドキュメントをローカルのサーバの URL 空間に
190 持ってくることもできます。この手法は<em>リバースプロキシ</em>と呼ばれています。
191 ウェブサーバが遠隔地のドキュメントを取得してクライアントに送り返すのが
192 プロキシサーバの動作のように見えるからです。クライアントにはドキュメントが
193 リバースプロキシサーバから送られてきているように見える点が通常の
196 <p>次の例では、クライアントが <code>/foo/</code> ディレクトリの下にある
197 ドキュメントをリクエストすると、サーバが <code>internal.example.com</code> の
198 <code>/bar/</code> ディレクトリから取得して、さもローカルサーバからの
199 ドキュメントのようにしてクライアントに返します。</p>
201 <div class="example"><p><code>
202 ProxyPass /foo/ http://internal.example.com/bar/<br />
203 ProxyPassReverse /foo/ http://internal.example.com/bar/
206 <p><code class="directive"><a href="./mod/mod_proxy.html#proxypass">ProxyPass</a></code> ディレクティブは
207 サーバが適切なドキュメントを取得するように設定し、
208 <code class="directive"><a href="./mod/mod_proxy.html#proxypassreverse">ProxyPassReverse</a></code> ディレクティブは
209 <code>internal.example.com</code> からのリダイレクトがローカルサーバの
210 適切なディレクトリを指すように書き換えます。ただし、ドキュメントの中の
211 リンクは書き換えられない、ということは知っておいてください。
212 ですから、<code>internal.example.com</code> への絶対パスによるリンクでは、
213 クライアントがプロキシサーバを抜け出して <code>internal.example.com</code> に
214 直接リクエストを送る、ということになります。</p>
215 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
216 <div class="section">
217 <h2><a name="rewrite" id="rewrite">リライトエンジン</a></h2>
219 <p>より一層強力な置換が必要なときは、<code class="module"><a href="./mod/mod_rewrite.html">mod_rewrite</a></code>
220 が提供するリライトエンジンが役に立つでしょう。
221 このモジュールにより提供されるディレクティブは
222 ブラウザの種類、リクエスト元の IP アドレスなどのリクエストの特徴を
223 使って送り返すコンテンツの場所を決めます。さらに、<code class="module"><a href="./mod/mod_rewrite.html">mod_rewrite</a></code>
224 は外部のデータベースファイルやプログラムを使ってリクエストの扱い方を
225 決めることもできます。リライトエンジンは上で挙げられている三つのマッピング
226 すべてを行なうことができます: 内部のリダイレクト (エイリアス)、
227 外部のリダイレクト、プロキシです。mod_rewrite を使う多くの実用的な例は
228 <a href="misc/rewriteguide.html">URL リライトガイド</a>
230 </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.gif" /></a></div>
231 <div class="section">
232 <h2><a name="notfound" id="notfound">File Not Found</a></h2>
234 <p>必ず、リクエストされた URL に対応するファイルがファイルシステムに
235 無いという場合が発生します。これが起こるのにはいくつかの理由があります。
236 場合によっては、ドキュメントを別の場所に移動した結果であることがあります。
237 この場合は、クライアントにリソースの新しい位置を知らせるために
238 <a href="#redirect">URL リダイレクション</a>を使うのが最善の方法です。
239 そうすることによって、リソースは新しい位置に移動しているけれども、
240 古いブックマークやリンクが動作し続けるようにすることができます。</p>
242 <p>"File Not Found" エラーのもう一つのよくある理由は、
243 ブラウザへの直接入力や HTML リンクからの偶発的な URL の入力間違いです。
244 Apache はこの問題を改善するために、<code class="module"><a href="./mod/mod_speling.html">mod_speling</a></code>
246 (訳注: 正しくは spelling) を提供しています。このモジュールが
247 使用されているときは、"File Not Found" エラーを横取りして、
248 似たファイル名のリソースを探します。もし一つだけ見つかった場合は
249 mod_speling はクライアントに正しい位置を知らせるために HTTP リダイレクトを
250 送ります。もし複数の「近い」ファイルが見つかった場合は、それら
251 代替となりえるもののリストがクライアントに表示されます。</p>
253 <p>mod_speling の非常に有用な機能は、大文字小文字を区別せずに
254 ファイル名を比較するものです。これは URL と unix の
255 ファイルシステムが両方とも大文字小文字を区別するものである、
256 ということをユーザが知らないシステムで役に立ちます。ただし、
257 時折の URL 訂正程度で済まず、mod_speling をより多く使用すると、サーバに
258 さらなる負荷がかかります。すべての「正しくない」リクエストの後に
259 URL のリダイレクトとクライアントからの新しいリクエストがくることに
262 <p>コンテンツの位置を決めようとするすべての試みが失敗すると、
263 Apache は、HTTP ステータスコード 404 (file not found) と共に
264 エラーページを返します。このエラーページの外観は
265 <code class="directive"><a href="./mod/core.html#errordocument">ErrorDocument</a></code>
267 <a href="custom-error.html">カスタムエラーレスポンス</a> と
268 <a href="misc/custom_errordocs.html">国際化サーバエラーレスポンス</a> で
269 説明されているように、柔軟な設定を行なうことができます。</p>
271 <div class="bottomlang">
272 <p><span>Available Languages: </span><a href="./en/urlmapping.html" hreflang="en" rel="alternate" title="English"> en </a> |
273 <a href="./ja/urlmapping.html" title="Japanese"> ja </a> |
274 <a href="./ko/urlmapping.html" hreflang="ko" rel="alternate" title="Korean"> ko </a> |
275 <a href="./tr/urlmapping.html" hreflang="tr" rel="alternate" title="Türkçe"> tr </a></p>
276 </div><div id="footer">
277 <p class="apache">Copyright 2009 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>
278 <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>