rewritemap.xml revision 2492b89218fc132ff9e006687c4aa514fe694f01
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen<?xml-stylesheet type="text/xsl" href="/style/manual.en.xsl"?>
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen<!-- $LastChangedRevision: 882992 $ -->
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen Licensed to the Apache Software Foundation (ASF) under one or more
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen contributor license agreements. See the NOTICE file distributed with
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen this work for additional information regarding copyright ownership.
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen The ASF licenses this file to You under the Apache License, Version 2.0
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen (the "License"); you may not use this file except in compliance with
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen the License. You may obtain a copy of the License at
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen Unless required by applicable law or agreed to in writing, software
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen distributed under the License is distributed on an "AS IS" BASIS,
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen See the License for the specific language governing permissions and
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen limitations under the License.
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen <p>This document supplements the <module>mod_rewrite</module>
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen<a href="/mod/mod_rewrite.html">reference documentation</a>. It describes
4a1711ab536d965e63d7be80e29f912287fe70b2rbowenthe use of the <directive module="mod_rewrite">RewriteMap</directive> directive,
4a1711ab536d965e63d7be80e29f912287fe70b2rbowenand provides examples of each of the various <code>RewriteMap</code> types.</p>
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen <note type="warning">Note that many of these examples won't work unchanged in your
4a1711ab536d965e63d7be80e29f912287fe70b2rbowenparticular server configuration, so it's important that you understand
4a1711ab536d965e63d7be80e29f912287fe70b2rbowenthem, rather than merely cutting and pasting the examples into your
4a1711ab536d965e63d7be80e29f912287fe70b2rbowenconfiguration.</note>
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen <seealso><a href="/mod/mod_rewrite.html">Module documentation</a></seealso>
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen <seealso><a href="intro.html">mod_rewrite introduction</a></seealso>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <seealso><a href="remapping.html">Redirection and remapping</a></seealso>
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen <seealso><a href="access.html">Controlling access</a></seealso>
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen <seealso><a href="vhosts.html">Virtual hosts</a></seealso>
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen <seealso><a href="advanced.html">Advanced techniques and tricks</a></seealso>
4a1711ab536d965e63d7be80e29f912287fe70b2rbowen <seealso><a href="avoid.html">When not to use mod_rewrite</a></seealso>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen The <directive module="mod_rewrite">RewriteMap</directive> directive
1a1f0f42c4b3840641897888fec7792af8ba384frbowen defines an external function which can be called in the context of
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <directive module="mod_rewrite">RewriteRule</directive> or
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <directive module="mod_rewrite">RewriteCond</directive> directives to
1a1f0f42c4b3840641897888fec7792af8ba384frbowen perform rewriting that is too complicated, or too specialized to be
1a1f0f42c4b3840641897888fec7792af8ba384frbowen performed just by regular expressions. The source of this lookup can
1a1f0f42c4b3840641897888fec7792af8ba384frbowen be any of the types listed in the sections below, and enumerated in
1a1f0f42c4b3840641897888fec7792af8ba384frbowen the <directive module="mod_rewrite">RewriteMap</directive> reference
1a1f0f42c4b3840641897888fec7792af8ba384frbowen documentation.</p>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>The syntax of the <code>RewriteMap</code> directive is as
1a1f0f42c4b3840641897888fec7792af8ba384frbowen follows:</p>
1a1f0f42c4b3840641897888fec7792af8ba384frbowenRewriteMap <em>MapName</em> <em>MapType</em>:<em>MapSource</em>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>The <a id="mapfunc" name="mapfunc"><em>MapName</em></a> is an
1a1f0f42c4b3840641897888fec7792af8ba384frbowen arbitray name that you assign to the map, and which you will use in
1a1f0f42c4b3840641897888fec7792af8ba384frbowen directives later on. Arguments are passed to the map via the
1a1f0f42c4b3840641897888fec7792af8ba384frbowen following syntax:</p>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <code>${</code> <em>MapName</em> <code>:</code> <em>LookupKey</em>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <code>}</code> <br/> <code>${</code> <em>MapName</em> <code>:</code>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <em>LookupKey</em> <code>|</code> <em>DefaultValue</em> <code>}</code>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>When such a construct occurs, the map <em>MapName</em> is
1a1f0f42c4b3840641897888fec7792af8ba384frbowen consulted and the key <em>LookupKey</em> is looked-up. If the
1a1f0f42c4b3840641897888fec7792af8ba384frbowen key is found, the map-function construct is substituted by
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <em>SubstValue</em>. If the key is not found then it is
1a1f0f42c4b3840641897888fec7792af8ba384frbowen substituted by <em>DefaultValue</em> or by the empty string
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>For example, you might define a
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>You would then be able to use this map in a
1a1f0f42c4b3840641897888fec7792af8ba384frbowen RewriteRule ^/ex/(.*) ${examplemap:$1}
1a1f0f42c4b3840641897888fec7792af8ba384frbowen<p>A default value can be specified in the event that nothing is found
1a1f0f42c4b3840641897888fec7792af8ba384frbowenin the map:</p>
1a1f0f42c4b3840641897888fec7792af8ba384frbowenRewriteRule ^/ex/(.*) ${examplemap:$1|/not_found.html}
1a1f0f42c4b3840641897888fec7792af8ba384frbowen<note><title>Per-directory and .htaccess context</title>
1a1f0f42c4b3840641897888fec7792af8ba384frbowenThe <code>RewriteMap</code> directive may not be used in
1a1f0f42c4b3840641897888fec7792af8ba384frbowen<Directory> sections or <code>.htaccess</code> files. You must
1a1f0f42c4b3840641897888fec7792af8ba384frbowendeclare the map in server or virtualhost context. You may use the map,
1a1f0f42c4b3840641897888fec7792af8ba384frbowen<code>RewriteCond</code> directives in those scopes. You just can't
1a1f0f42c4b3840641897888fec7792af8ba384frbowen<p>The sections that follow describe the various <em>MapType</em>s that
1a1f0f42c4b3840641897888fec7792af8ba384frbowenmay be used, and give examples of each.</p>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>When a MapType of <code>txt</code>is used, the MapSource is a filesystem path to a
1a1f0f42c4b3840641897888fec7792af8ba384frbowen plain-text mapping file, containing space-separated key/value pair
1a1f0f42c4b3840641897888fec7792af8ba384frbowen per line. Optionally, a line may be contain a comment, starting with
1a1f0f42c4b3840641897888fec7792af8ba384frbowen a '#' character.</p>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>For example, the following might be valid entries in a map
1a1f0f42c4b3840641897888fec7792af8ba384frbowen # Comment line<br />
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <strong><em>MatchingKey</em> <em>SubstValue</em></strong><br />
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <strong><em>MatchingKey</em> <em>SubstValue</em></strong> # comment<br />
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>When the RewriteMap is invoked the argument is looked for in the
1a1f0f42c4b3840641897888fec7792af8ba384frbowen first argument of a line, and, if found, the substitution value is
1a1f0f42c4b3840641897888fec7792af8ba384frbowen returned.</p>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>For example, we might use a mapfile to translate product names to
1a1f0f42c4b3840641897888fec7792af8ba384frbowen product IDs for easier-to-remember URLs, using the following
1a1f0f42c4b3840641897888fec7792af8ba384frbowen recipe:</p>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen RewriteMap product2id txt:/etc/apache2/productmap.txt<br />
1a1f0f42c4b3840641897888fec7792af8ba384frbowen RewriteRule ^/product/(.*) /prods.php?id=${product2id:$1|NOTFOUND} [PT]
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>We assume here that the <code>prods.php</code> script knows what
1a1f0f42c4b3840641897888fec7792af8ba384frbowen to do when it received an argument of <code>id=NOTFOUND</code> when
1a1f0f42c4b3840641897888fec7792af8ba384frbowen a product is not found in the lookup map.</p>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>The file <code>/etc/apache2/productmap.txt</code> then contains
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen the following:</p>
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowentelevision 993<br />
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowenstereo 198<br />
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowenfishingrod 043<br />
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowenbasketball 418<br />
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowentelephone 328
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen <p>Thus, when <code>http://example.com/product/television</code> is
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen requested, the <code>RewriteRule</code> is applied, and the request
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen is internally mapped to <code>/prods.php?id=993</code>.</p>
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen The example given is crafted to be used in server or virtualhost
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen scope. If you're planning to use this in a <code>.htaccess</code>
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen file, you'll need to remove the leading slash from the rewrite
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen pattern in order for it to match anything:
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen RewriteRule ^product/(.*) /prods.php?id=${product2id:$1|NOTFOUND} [PT]
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen The looked-up keys are cached by httpd until the <code>mtime</code>
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen (modified time) of the mapfile changes, or the httpd server is
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen restarted. This ensures better performance on maps that are called
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen by many requests.
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen <p>When a MapType of <code>rnd</code> is used, the MapSource is a
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen filesystem path to a plain-text mapping file, each line of which
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen contains a key, and one or more values separated by <code>|</code>.
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen One of these values will be chosen at random if the key is
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen matched.</p>
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen <p>For example, you might use the following map
1a1f0f42c4b3840641897888fec7792af8ba384frbowen file and directives to provide a random load balancing between
1a1f0f42c4b3840641897888fec7792af8ba384frbowen several back-end server, via a reverse-proxy. Images are sent
1a1f0f42c4b3840641897888fec7792af8ba384frbowen to one of the servers in the 'static' pool, while everything
1a1f0f42c4b3840641897888fec7792af8ba384frbowen else is sent to one of the 'dynamic' pool.</p>
1a1f0f42c4b3840641897888fec7792af8ba384frbowenstatic www1|www2|www3|www4<br />
1a1f0f42c4b3840641897888fec7792af8ba384frbowendynamic www5|www6
1a1f0f42c4b3840641897888fec7792af8ba384frbowen RewriteRule ^/(.*\.(png|gif|jpg)) http://${servers:static}/$1 [NC,P,L]<br/>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen RewriteRule ^/(.*) http://${servers:dynamic}/$1 [P,L]
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>So, when an image is requested and the first of these rules is
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <code>static</code> in the map file, which returns one of the
1a1f0f42c4b3840641897888fec7792af8ba384frbowen specified hostnames at random, which is then used in the
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>If you wanted to have one of the servers more likely to be chosen
1a1f0f42c4b3840641897888fec7792af8ba384frbowen (for example, if one of the server has more memory than the others,
1a1f0f42c4b3840641897888fec7792af8ba384frbowen and so can handle more requests) simply list it more times in the
1a1f0f42c4b3840641897888fec7792af8ba384frbowen map file.</p>
1a1f0f42c4b3840641897888fec7792af8ba384frbowenstatic www1|www1|www2|www3|www4
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>When a MapType of <code>dbm</code> is used, the MapSource is a
1a1f0f42c4b3840641897888fec7792af8ba384frbowen filesystem path to a DBM database file containing key/value pairs to
1a1f0f42c4b3840641897888fec7792af8ba384frbowen be used in the mapping. This works exactly the same way as the
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <code>txt</code> map, but is much faster, because a DBM is indexed,
1a1f0f42c4b3840641897888fec7792af8ba384frbowen whereas a text file is not. This allows more rapid access to the
1a1f0f42c4b3840641897888fec7792af8ba384frbowen desired key.</p>
1a1f0f42c4b3840641897888fec7792af8ba384frbowen <p>You may optionally specify a particular dbm type:</p>
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen RewriteMap examplemap dbm=sdbm:/etc/apache/mapfile.dbm
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen <p>The type can be sdbm, gdbm, ndbm or db.
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen However, it is recommended that you just use the <a
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen href="/programs/httxt2dbm.html">httxt2dbm</a> utility that is
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen provided with Apache HTTP Server, as it will use the correct DBM library,
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen matching the one that was used when httpd itself was built.</p>
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen <p>To create a dbm file, first create a text map file as described
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen<p>You can then reference the resulting file in your
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen<p>Note that with some dbm types, more than one file is generated, with
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowena common base name. For example, you may have two files named
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen<code>mapfile.map.dir</code> and <code>mapfiile.map.pag</code>. This is
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowennormal, and you need only use the base name <code>mapfile.map</code> in
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowenThe looked-up keys are cached by httpd until the <code>mtime</code>
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowen(modified time) of the mapfile changes, or the httpd server is
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowenrestarted. This ensures better performance on maps that are called
13e125c14cbafff43783b7f3aed11de6d4cb5b14rbowenby many requests.