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