一个基于一定规则的实时重写URL请求的引擎 |
扩展(E) |
rewrite_module |
mod_rewrite.c |
仅在 Apache 1.3 及以后的版本中可用 |
此模块提供了一个基于正则表达式分析器的重写引擎来实时重写URL请求。它支持每个完整规则可以拥有不限数量的子规则以及附加条件规则的灵活而且强大的URL操作机制。此URL操作可以依赖于各种测试,比如服务器变量、环境变量、HTTP头、时间标记,甚至各种格式的用于匹配URL组成部分的查找数据库。
此模块可以操作URL的所有部分(包括路径信息部分),在服务器级的(httpd.conf
)和目录级的(.htaccess
)配置都有效,还可以生成最终请求字符串。此重写操作的结果可以是内部子处理,也可以是外部请求的转向,甚至还可以是内部代理处理。
但是,所有这些功能和灵活性带来一个问题,那就是复杂性,因此,不要指望一天之内就能看懂整个模块。
更多的讨论、细节、示例,请查看详细的URL重写文档。
在Apache 1.3.20中,TestString和Substitution中的特殊字符可以用前导斜杠(\)来实现转义(即忽略其特殊含义而视之为普通字符)。 比如,Substitution可以用"\$
"来包含一个美元符号,以避免mod_rewrite把它视为反向引用。
此模块会跟踪两个额外的(非标准)CGI/SSI环境变量,SCRIPT_URL
和SCRIPT_URI
。他们包含了当前资源的逻辑网络视图,而标准CGI/SSI变量SCRIPT_NAME
和SCRIPT_FILENAME
包含的是物理系统视图。
注意:这些变量保持的是其最初被请求时的URI/URL,即在任何重写操作之前的URI/URL。其重要性在于他们是重写操作重写URL到物理路径名的原始依据。
SCRIPT_NAME=/sw/lib/w3s/tree/global/u/rse/.www/index.html SCRIPT_FILENAME=/u/rse/.www/index.html SCRIPT_URL=/u/rse/ SCRIPT_URI=http://en1.engelschall.com/u/rse/
设置目录级重写的基准URL |
RewriteBase URL-path |
参见使用方法 |
directory, .htaccess |
FileInfo |
扩展(E) |
mod_rewrite |
RewriteBase
指令显式地设置了目录级重写的基准URL。在下文中,你将看到RewriteRule
可以用于目录级的配置文件中(.htaccess
)并在局部范围内起作用,即规则实际处理的只是剥离了本地路径前缀的一部分。处理结束后,这个路径会被自动地附着回去。默认值是"RewriteBase
physical-directory-path"。
在对一个新的URL进行替换时,此模块必须把这个URL重新注入到服务器处理中。为此,它必须知道其对应的URL前缀或者说URL基准。通常,此前缀就是对应的文件路径。但是,大多数网站URL不是直接对应于其物理文件路径的,因而一般不能做这样的假定! 所以在这种情况下,就必须用RewriteBase
指令来指定正确的URL前缀。
例如,目录级配置文件内容如下:
# /abc/def/.htaccess -- /abc/def 目录的配置文件 # 注意:/abc/def 是 /xyz 的物理路径(例如存在一条'Alias /xyz /abc/def'指令)。 RewriteEngine On # 让服务器知道我们使用的是 /xyz 而不是物理路径 /abc/def RewriteBase /xyz # 重写规则 RewriteRule ^oldstuff\.html$ newstuff.html
上述例子中,对/xyz/oldstuff.html
的请求被正确地重写为对物理文件/abc/def/newstuff.html
的请求。
以下列出了内部处理的详细步骤:
请求: /xyz/oldstuff.html 内部处理过程: /xyz/oldstuff.html -> /abc/def/oldstuff.html (per-server Alias) /abc/def/oldstuff.html -> /abc/def/newstuff.html (per-dir RewriteRule) /abc/def/newstuff.html -> /xyz/newstuff.html (per-dir RewriteBase) /xyz/newstuff.html -> /abc/def/newstuff.html (per-server Alias) 结果: /abc/def/newstuff.html
虽然这个过程看来很繁复,但是由于目录级重写的到来时机已经太晚了,它不得不把这个(重写)请求重新注入到Apache核心中,所以Apache内部确实是这样处理的。但是:它的开销并不象看起来的那样大,因为重新注入完全在Apache服务器内部进行,而且这样的过程在Apache内部也为其他许多操作所使用。所以,你可以充分信任其设计和实现是正确的。
定义重写发生的条件 |
RewriteCond TestString CondPattern [flags] |
server config, virtual host, directory, .htaccess |
FileInfo |
扩展(E) |
mod_rewrite |
RewriteCond
指令定义了规则生效的条件,即在一个RewriteRule
指令之前可以有一个或多个RewriteCond
指令。条件之后的重写规则仅在当前URI与Pattern匹配并且满足此处的条件(TestString能够与CondPattern匹配)时才会起作用。
TestString是一个纯文本的字符串,但是还可以包含下列可扩展的成分:
$N
RewriteRule
指令的)RewriteCond
中的与Pattern匹配的分组成分(圆括号!)。 %N
RewriteCond
条件中最后符合的条件中的分组成分(圆括号!)。 ${mapname:key|default}
%{
NAME_OF_VARIABLE}
HTTP_USER_AGENT HTTP_REFERER HTTP_COOKIE HTTP_FORWARDED HTTP_HOST HTTP_PROXY_CONNECTION HTTP_ACCEPT |
REMOTE_ADDR REMOTE_HOST REMOTE_PORT REMOTE_USER REMOTE_IDENT REQUEST_METHOD SCRIPT_FILENAME PATH_INFO QUERY_STRING AUTH_TYPE |
|
DOCUMENT_ROOT SERVER_ADMIN SERVER_NAME SERVER_ADDR SERVER_PORT SERVER_PROTOCOL SERVER_SOFTWARE |
TIME_YEAR TIME_MON TIME_DAY TIME_HOUR TIME_MIN TIME_SEC TIME_WDAY TIME |
API_VERSION THE_REQUEST REQUEST_URI REQUEST_FILENAME IS_SUBREQ HTTPS |
这些变量都对应于类似命名的HTTP MIME头、Apache服务器的C变量、Unix系统中的struct tm
字段,其中的大多数在其他的手册或者CGI规范中都有说明。 其中为mod_rewrite所特有的变量如下:
IS_SUBREQ
API_VERSION
THE_REQUEST
GET /index.html HTTP/1.1
")。它不包含任何浏览器发送的其它头信息。
REQUEST_URI
REQUEST_FILENAME
HTTPS
mod_ssl
是否已经加载,该变量都可以安全的使用)。
其它注意事项:
request_rec
结构中的filename
字段。 第一个就是大家都知道的CGI变量名,而第二个则是REQUEST_URI(request_rec
结构中的uri
字段)的一个副本。 %{ENV:variable}
,其中的variable可以是任意环境变量。它是通过查找Apache内部结构或者(如果没找到的话)由Apache服务器进程通过getenv()
得到的。 %{SSL:variable}
,其中的variable可以是一个SSL环境变量的名字,无论mod_ssl
模块是否已经加载都可以使用(未加载时为空字符串)。比如:%{SSL:SSL_CIPHER_USEKEYSIZE}
将会被替换为128
。 %{HTTP:header}
,其中的header可以是任意HTTP MIME头的名称。它总是可以通过查找HTTP请求而得到。比如:%{HTTP:Proxy-Connection}
将被替换为Proxy-Connection:
HTTP头的值。 %{LA-U:variable}
,variable的最终值在执行一个内部(基于URL的)子请求后确定。 当需要使用一个目前未知但是会在之后的过程中设置的变量的时候,就可以使用这个方法。 例如,需要在服务器级配置(httpd.conf
文件)中根据REMOTE_USER
变量进行重写, 就必须使用%{LA-U:REMOTE_USER}
。因为此变量是由URL重写(mod_rewrite)步骤之后的认证步骤设置的。 但是另一方面,因为mod_rewrite是通过API修正步骤来实现目录级(.htaccess
文件)配置的, 而认证步骤先于API修正步骤,所以可以用%{REMOTE_USER}
。
%{LA-F:variable}
,variable的最终值在执行一个内部(基于文件名的)子请求后确定。 大多数情况下和上述的LA-U是相同的。 CondPattern是条件模式,即一个应用于当前TestString实例的正则表达式。TestString将被首先计算,然后再与CondPattern匹配。
注意:CondPattern是一个perl兼容的正则表达式,但是还有若干增补:
!
'(惊叹号)来指定不匹配。 ""
(两个双引号),则TestString将与空字符串进行比较。 [flags]
作为RewriteCond
指令的第三个参数。flags是一个以逗号分隔的以下标记的列表:
nocase|NC
'(忽略大小写)ornext|OR
'(或下一条件)RewriteCond %{REMOTE_HOST} ^host1.* [OR] RewriteCond %{REMOTE_HOST} ^host2.* [OR] RewriteCond %{REMOTE_HOST} ^host3.* RewriteRule ... 针对这3个主机的规则集 ...
举例
如果要按请求头中的"User-Agent:
"重写一个站点的主页,可以这样写:
RewriteCond %{HTTP_USER_AGENT} ^Mozilla.* RewriteRule ^/$ /homepage.max.html [L] RewriteCond %{HTTP_USER_AGENT} ^Lynx.* RewriteRule ^/$ /homepage.min.html [L] RewriteRule ^/$ /homepage.std.html [L]
解释:如果你使用的浏览器识别标志是'Mozilla',则你将得到内容最大化的主页(含有Frames等等)。如果你使用的是(基于终端的)Lynx,则你得到的是内容最小化的主页(不含table等等)。如果上述条件都不满足(使用的是其他浏览器),则你得到的是一个标准的主页。
打开或关闭运行时的重写引擎 |
RewriteEngine on|off |
RewriteEngine off |
server config, virtual host, directory, .htaccess |
FileInfo |
扩展(E) |
mod_rewrite |
RewriteEngine
指令打开或关闭运行时的重写引擎。如果设置为off
,则此模块在运行时不执行任何重写操作, 同时也不更新SCRIPT_URx
环境变量。
使用该指令可以使此模块无效,而无须注释所有的RewriteRule
指令!
注意:默认情况下,重写配置是不可继承的,也就是必须在每个需要使用重写引擎的虚拟主机中设置一个RewriteEngine on
指令。
设置RewriteMap 同步所使用的锁文件名 |
RewriteLock file-path |
server config |
扩展(E) |
mod_rewrite |
此指令设置mod_rewrite为了和RewriteMap
程序通讯而使用的同步锁文件的名称。 在需要使用重写映射表程序(rewriting map-program)时,它必须是一个本地路径(而不能是一个NFS挂接设备)。对其他类型的重写映射表(rewriting map),则无此要求。
设置重写引擎日志的文件名 |
RewriteLog file-path |
server config, virtual host |
扩展(E) |
mod_rewrite |
RewriteLog
指令设置用于记录所有重写操作的日志文件的名称。如果此文件名不以斜杠('/
')开头,则它是相对于Server Root的,此指令应该在每个服务器级别的配置中仅仅出现一次。
/dev/null
,因为,虽然重写引擎不能输出记录了,但仍会在内部建立这个日志文件,
这样会使服务器速度降低,而且对管理员毫无益处!要关闭日志,可以删除或注解
RewriteLog
指令, 或者使用"
RewriteLogLevel 0
"的设置
RewriteLog "/usr/local/var/apache/logs/rewrite.log"
设置重写日志的详细程度 |
RewriteLogLevel Level |
RewriteLogLevel 0 |
server config, virtual host |
扩展(E) |
mod_rewrite |
RewriteLogLevel
指令设置重写引擎日志的详细程度的级别。0(默认级别)意味着不记录,而9或更大的值意味着记录所有操作。
要关闭重写引擎日志,可以简单地将Level设为0,以关闭所有重写操作的记录。
RewriteLogLevel 3
定义用于关键词查找的映射函数 |
RewriteMap MapName MapType:MapSource |
server config, virtual host |
扩展(E) |
mod_rewrite |
Apache 2.0.41 及以后的版本中可以使用不同的dbm类型 |
RewriteMap
指令定义了一个映射表(Rewriting Map),映射函数将使用该表来查找关键字然后插入/替换字段。此查找操作的源可以是多种类型。
MapName是映射表的名称,指定了一个映射函数,用于重写规则的字符串替换,它可以是下列形式之一:
${
MapName:
LookupKey}
${
MapName:
LookupKey|
DefaultValue}
如果使用了这样的形式,则会在MapName中查找关键词LookupKey。如果找到了,则被替换成SubstValue; 如果没有找到,则被替换成DefaultValue,如果没有指定DefaultValue,则被替换成空字符串。
例如,你可能定义这样一个RewriteMap
:
RewriteMap examplemap txt:/path/to/file/map.txt
然后你就可以像下面这样在RewriteRule
中使用该映射:
RewriteRule ^/ex/(.*) ${examplemap:$1}
可以使用下列MapType和MapSource的组合:
txt
, MapSource: 有效的Unix文件系统文件名 这是重写映射表的标准形式。MapSource是一个纯文本文件,包含空行、注释行(以字符'#'打头),以及每行一个的替换对,如下所示:
MatchingKey SubstValue
## map.txt -- rewriting map Ralf.S.Engelschall rse # Bastard Operator From Hell Mr.Joe.Average joe # Mr. Average
RewriteMap real-to-user txt:/path/to/file/map.txt
rnd
, MapSource: 有效的Unix文件系统文件名 这个与上述的标准纯文本很相似,但它有一个特殊的后处理特性:查找完毕后,会解析其中包含的"|
"符号(含义为"或")。 也就是说,会随机地选择其中之一作为返回值。虽然这看似毫无意义,但设计它的意图是在一个查找值是服务器名称的反向代理环境中实现负载平衡。
例子
## map.txt -- rewriting map static www1|www2|www3|www4 dynamic www5|www6
RewriteMap servers rnd:/path/to/file/map.txt
RewriteRule ^/(.*\.(png|gif|jpg)) http://${servers:static}/$1 [NC,P,L]
RewriteRule ^/(.*) http://${servers:dynamic}/$1 [P,L]
dbm[=type]
, MapSource: 有效的Unix文件系统文件名 这里的源是一个二进制格式的DBM文件,包含了与纯文本相同的内容,但是因为它有优化了的特殊表现形式,使它的查找速度明显快得多。 此type可以是sdbm, gdbm, ndbm, db(由编译时配置决定)。如果省略type,则使用编译时选择的缺省值。 你可以使用任何DBM工具或者下列Perl脚本来创建这个文件,但必须保证DBM的类型正确。建立NDBM文件的例子如下:
#!/path/to/bin/perl ## ## txt2dbm -- 将 txt 映射表转换为 dbm 格式 ## use NDBM_File; use Fcntl; ($txtmap, $dbmmap) = @ARGV; open(TXT, "<$txtmap") or die "Couldn't open $txtmap!\n"; tie (%DB, 'NDBM_File', $dbmmap,O_RDWR|O_TRUNC|O_CREAT, 0644) or die "Couldn't create $dbmmap!\n"; while (<TXT>) { next if (/^\s*#/ or /^\s*$/); $DB{$1} = $2 if (/^\s*(\S+)\s+(\S+)/); } untie %DB; close(TXT);
$ txt2dbm map.txt map.db
int
, MapSource: Apache内部函数 这里的源是一个Apache的内部函数。目前,还不能由你自己建立,只能使用下列已经存在的函数:
prg
, MapSource: 有效的Unix文件系统文件名 这里的源是一个程序,而不是一个映射表文件。程序设计语言可以随意选择,但最终结果必须是可执行的(或者是目标代码,或者是首行为'#!/path/to/interpreter
'的脚本)。
此程序仅在Apache服务器启动时启动一次,随后通过stdin
和stdout
文件句柄与重写引擎交互。 对每个映射函数的查找操作,它从stdin
接收以回车结束的查找关键词,然后把查找的结果以回车结束反馈到stdout
,如果查找失败,则返回四个字符的字符串"NULL"(对给定的关键词没有对应的值)。此程序的最简单形式是一个1:1的映射(即:key == value),例如:
#!/usr/bin/perl $| = 1; while (<STDIN>) { # ...在这里放置转换和查找... printApache模块 mod_rewrite
说明 状态 模块名 源文件 兼容性
一个基于一定规则的实时重写URL请求的引擎 扩展(E) rewrite_module mod_rewrite.c 仅在 Apache 1.3 及以后的版本中可用 概述
此模块提供了一个基于正则表达式分析器的重写引擎来实时重写URL请求。它支持每个完整规则可以拥有不限数量的子规则以及附加条件规则的灵活而且强大的URL操作机制。此URL操作可以依赖于各种测试,比如服务器变量、环境变量、HTTP头、时间标记,甚至各种格式的用于匹配URL组成部分的查找数据库。
此模块可以操作URL的所有部分(包括路径信息部分),在服务器级的(
httpd.conf
)和目录级的(.htaccess
)配置都有效,还可以生成最终请求字符串。此重写操作的结果可以是内部子处理,也可以是外部请求的转向,甚至还可以是内部代理处理。但是,所有这些功能和灵活性带来一个问题,那就是复杂性,因此,不要指望一天之内就能看懂整个模块。
更多的讨论、细节、示例,请查看详细的URL重写文档。
特殊字符的引用
在Apache 1.3.20中,TestString和Substitution中的特殊字符可以用前导斜杠(\)来实现转义(即忽略其特殊含义而视之为普通字符)。 比如,Substitution可以用"
\$
"来包含一个美元符号,以避免mod_rewrite把它视为反向引用。环境变量
此模块会跟踪两个额外的(非标准)CGI/SSI环境变量,
SCRIPT_URL
和SCRIPT_URI
。他们包含了当前资源的逻辑网络视图,而标准CGI/SSI变量SCRIPT_NAME
和SCRIPT_FILENAME
包含的是物理系统视图。注意:这些变量保持的是其最初被请求时的URI/URL,即在任何重写操作之前的URI/URL。其重要性在于他们是重写操作重写URL到物理路径名的原始依据。
示例
SCRIPT_NAME=/sw/lib/w3s/tree/global/u/rse/.www/index.html SCRIPT_FILENAME=/u/rse/.www/index.html SCRIPT_URL=/u/rse/ SCRIPT_URI=http://en1.engelschall.com/u/rse/RewriteBase 指令
说明 语法 默认值 作用域 覆盖项 状态 模块
设置目录级重写的基准URL RewriteBase URL-path
参见使用方法
directory, .htaccess FileInfo 扩展(E) mod_rewrite
RewriteBase
指令显式地设置了目录级重写的基准URL。在下文中,你将看到RewriteRule
可以用于目录级的配置文件中(.htaccess
)并在局部范围内起作用,即规则实际处理的只是剥离了本地路径前缀的一部分。处理结束后,这个路径会被自动地附着回去。默认值是"RewriteBase
physical-directory-path"。在对一个新的URL进行替换时,此模块必须把这个URL重新注入到服务器处理中。为此,它必须知道其对应的URL前缀或者说URL基准。通常,此前缀就是对应的文件路径。但是,大多数网站URL不是直接对应于其物理文件路径的,因而一般不能做这样的假定! 所以在这种情况下,就必须用
RewriteBase
指令来指定正确的URL前缀。例如,目录级配置文件内容如下:
# /abc/def/.htaccess -- /abc/def 目录的配置文件 # 注意:/abc/def 是 /xyz 的物理路径(例如存在一条'Alias /xyz /abc/def'指令)。 RewriteEngine On # 让服务器知道我们使用的是 /xyz 而不是物理路径 /abc/def RewriteBase /xyz # 重写规则 RewriteRule ^oldstuff\.html$ newstuff.html上述例子中,对
/xyz/oldstuff.html
的请求被正确地重写为对物理文件/abc/def/newstuff.html
的请求。仅供Apache Hacker们参考
以下列出了内部处理的详细步骤:
请求: /xyz/oldstuff.html 内部处理过程: /xyz/oldstuff.html -> /abc/def/oldstuff.html (per-server Alias) /abc/def/oldstuff.html -> /abc/def/newstuff.html (per-dir RewriteRule) /abc/def/newstuff.html -> /xyz/newstuff.html (per-dir RewriteBase) /xyz/newstuff.html -> /abc/def/newstuff.html (per-server Alias) 结果: /abc/def/newstuff.html虽然这个过程看来很繁复,但是由于目录级重写的到来时机已经太晚了,它不得不把这个(重写)请求重新注入到Apache核心中,所以Apache内部确实是这样处理的。但是:它的开销并不象看起来的那样大,因为重新注入完全在Apache服务器内部进行,而且这样的过程在Apache内部也为其他许多操作所使用。所以,你可以充分信任其设计和实现是正确的。
RewriteCond 指令
说明 语法 作用域 覆盖项 状态 模块
定义重写发生的条件 RewriteCond TestString CondPattern [flags]
server config, virtual host, directory, .htaccess FileInfo 扩展(E) mod_rewrite
RewriteCond
指令定义了规则生效的条件,即在一个RewriteRule
指令之前可以有一个或多个RewriteCond
指令。条件之后的重写规则仅在当前URI与Pattern匹配并且满足此处的条件(TestString能够与CondPattern匹配)时才会起作用。TestString是一个纯文本的字符串,但是还可以包含下列可扩展的成分:
- RewriteRule反向引用 ,引用方法是:
(0 <= N <= 9)引用当前(带有若干
$N
RewriteRule
指令的)RewriteCond
中的与Pattern匹配的分组成分(圆括号!)。- RewriteCond反向引用 ,引用方法是:
(1 <= N <= 9)引用当前若干
%N
RewriteCond
条件中最后符合的条件中的分组成分(圆括号!)。- RewriteMap扩展 ,引用方法是:
细节请参见RewriteMap 指令。
${mapname:key|default}
- 服务器变量 ,引用方法是:
NAME_OF_VARIABLE可以是下表列出的字符串之一:
%{
NAME_OF_VARIABLE}
HTTP头 连接与请求 HTTP_USER_AGENT
HTTP_REFERER
HTTP_COOKIE
HTTP_FORWARDED
HTTP_HOST
HTTP_PROXY_CONNECTION
HTTP_ACCEPT
REMOTE_ADDR
REMOTE_HOST
REMOTE_PORT
REMOTE_USER
REMOTE_IDENT
REQUEST_METHOD
SCRIPT_FILENAME
PATH_INFO
QUERY_STRING
AUTH_TYPE
服务器自身 日期和时间 其它 DOCUMENT_ROOT
SERVER_ADMIN
SERVER_NAME
SERVER_ADDR
SERVER_PORT
SERVER_PROTOCOL
SERVER_SOFTWARE
TIME_YEAR
TIME_MON
TIME_DAY
TIME_HOUR
TIME_MIN
TIME_SEC
TIME_WDAY
TIME
API_VERSION
THE_REQUEST
REQUEST_URI
REQUEST_FILENAME
IS_SUBREQ
HTTPS
这些变量都对应于类似命名的HTTP MIME头、Apache服务器的C变量、Unix系统中的
struct tm
字段,其中的大多数在其他的手册或者CGI规范中都有说明。 其中为mod_rewrite所特有的变量如下:IS_SUBREQ
- 如果正在处理的请求是一个子请求,它将包含字符串"true",否则就是"false"。模块为了解析URI中的附加文件,可能会产生子请求。
API_VERSION
- 这是正在使用中的Apache模块API(服务器和模块之间内部接口)的版本, 其定义位于include/ap_mmn.h中。此模块API版本对应于正在使用的Apache的版本(比如在Apache 1.3.14的发行版中这个值是19990320:10)。 通常,对它感兴趣的是模块的开发者。
THE_REQUEST
- 这是由浏览器发送的完整的HTTP请求行(比如:"
GET /index.html HTTP/1.1
")。它不包含任何浏览器发送的其它头信息。REQUEST_URI
- 这是在HTTP请求行中所请求的资源(比如上述例子中的"/index.html")。
REQUEST_FILENAME
- 这是与请求相匹配的完整的本地文件系统的文件路径名。
HTTPS
- 如果连接使用了SSL/TLS,它将包含字符串"on",否则就是"off"(无论
mod_ssl
是否已经加载,该变量都可以安全的使用)。其它注意事项:
- SCRIPT_FILENAME和REQUEST_FILENAME包含的值是相同的——即Apache服务器内部的
request_rec
结构中的filename
字段。 第一个就是大家都知道的CGI变量名,而第二个则是REQUEST_URI(request_rec
结构中的uri
字段)的一个副本。- 特殊形式:
%{ENV:variable}
,其中的variable可以是任意环境变量。它是通过查找Apache内部结构或者(如果没找到的话)由Apache服务器进程通过getenv()
得到的。- 特殊形式:
%{SSL:variable}
,其中的variable可以是一个SSL环境变量的名字,无论mod_ssl
模块是否已经加载都可以使用(未加载时为空字符串)。比如:%{SSL:SSL_CIPHER_USEKEYSIZE}
将会被替换为128
。- 特殊形式:
%{HTTP:header}
,其中的header可以是任意HTTP MIME头的名称。它总是可以通过查找HTTP请求而得到。比如:%{HTTP:Proxy-Connection}
将被替换为Proxy-Connection:
HTTP头的值。- 预设形式:
%{LA-U:variable}
,variable的最终值在执行一个内部(基于URL的)子请求后确定。 当需要使用一个目前未知但是会在之后的过程中设置的变量的时候,就可以使用这个方法。例如,需要在服务器级配置(
httpd.conf
文件)中根据REMOTE_USER
变量进行重写, 就必须使用%{LA-U:REMOTE_USER}
。因为此变量是由URL重写(mod_rewrite)步骤之后的认证步骤设置的。 但是另一方面,因为mod_rewrite是通过API修正步骤来实现目录级(.htaccess
文件)配置的, 而认证步骤先于API修正步骤,所以可以用%{REMOTE_USER}
。- 预设形式:
%{LA-F:variable}
,variable的最终值在执行一个内部(基于文件名的)子请求后确定。 大多数情况下和上述的LA-U是相同的。CondPattern是条件模式,即一个应用于当前TestString实例的正则表达式。TestString将被首先计算,然后再与CondPattern匹配。
注意:CondPattern是一个perl兼容的正则表达式,但是还有若干增补:
- 可以在CondPattern串的开头使用'
!
'(惊叹号)来指定不匹配。- CondPatterns有若干特殊的变种。除了正则表达式的标准用法,还有下列用法:
- '<CondPattern'(词典顺序的小于)
将CondPattern视为纯字符串,与TestString按词典顺序进行比较。如果TestString小于CondPattern则为真。- '>CondPattern'(词典顺序的大于)
将CondPattern视为纯字符串,与TestString按词典顺序进行比较。如果TestString大于CondPattern则为真。- '=CondPattern'(词典顺序的等于)
将CondPattern视为纯字符串,与TestString按词典顺序进行比较。如果TestString等于CondPattern(两个字符串逐个字符地完全相等)则为真。如果CondPattern是""
(两个双引号),则TestString将与空字符串进行比较。- '-d'(目录)
将TestString视为一个路径名并测试它是否为一个存在的目录。- '-f'(常规文件)
将TestString视为一个路径名并测试它是否为一个存在的常规文件。- '-s'(非空的常规文件)
将TestString视为一个路径名并测试它是否为一个存在的、尺寸大于0的常规文件。- '-l'(符号连接)
将TestString视为一个路径名并测试它是否为一个存在的符号连接。- '-x'(可执行)
将TestString视为一个路径名并测试它是否为一个存在的、具有可执行权限的文件。该权限由操作系统检测。- '-F'(对子请求存在的文件)
检查TestString是否为一个有效的文件,而且可以在服务器当前的访问控制配置下被访问。它使用一个内部子请求来做检查,由于会降低服务器的性能,所以请谨慎使用!- '-U'(对子请求存在的URL)
检查TestString是否为一个有效的URL,而且可以在服务器当前的访问控制配置下被访问。它使用一个内部子请求来做检查,由于会降低服务器的性能,所以请谨慎使用!注意
所有这些测试都可以用惊叹号作前缀('!')以实现测试条件的反转。- 还可以在CondPattern之后追加特殊的标记
[flags]
作为RewriteCond
指令的第三个参数。flags是一个以逗号分隔的以下标记的列表:
- '
nocase|NC
'(忽略大小写)
它使测试忽略大小写,扩展后的TestString和CondPattern中'A-Z' 和'a-z'是没有区别的。此标记仅用于TestString和CondPattern的比较,而对文件系统和子请求的检查不起作用。- '
ornext|OR
'(或下一条件)
它以OR方式组合若干规则的条件,而不是隐含的AND。典型的例子如下:如果不用这个标记,你就必须要书写三次条件/规则对。RewriteCond %{REMOTE_HOST} ^host1.* [OR] RewriteCond %{REMOTE_HOST} ^host2.* [OR] RewriteCond %{REMOTE_HOST} ^host3.* RewriteRule ... 针对这3个主机的规则集 ...举例
如果要按请求头中的"
User-Agent:
"重写一个站点的主页,可以这样写:RewriteCond %{HTTP_USER_AGENT} ^Mozilla.* RewriteRule ^/$ /homepage.max.html [L] RewriteCond %{HTTP_USER_AGENT} ^Lynx.* RewriteRule ^/$ /homepage.min.html [L] RewriteRule ^/$ /homepage.std.html [L]解释:如果你使用的浏览器识别标志是'Mozilla',则你将得到内容最大化的主页(含有Frames等等)。如果你使用的是(基于终端的)Lynx,则你得到的是内容最小化的主页(不含table等等)。如果上述条件都不满足(使用的是其他浏览器),则你得到的是一个标准的主页。
RewriteEngine 指令
说明 语法 默认值 作用域 覆盖项 状态 模块
打开或关闭运行时的重写引擎 RewriteEngine on|off
RewriteEngine off
server config, virtual host, directory, .htaccess FileInfo 扩展(E) mod_rewrite
RewriteEngine
指令打开或关闭运行时的重写引擎。如果设置为off
,则此模块在运行时不执行任何重写操作, 同时也不更新SCRIPT_URx
环境变量。使用该指令可以使此模块无效,而无须注释所有的
RewriteRule
指令!注意:默认情况下,重写配置是不可继承的,也就是必须在每个需要使用重写引擎的虚拟主机中设置一个
RewriteEngine on
指令。RewriteLock 指令
说明 语法 作用域 状态 模块
设置 RewriteMap
同步所使用的锁文件名RewriteLock file-path
server config 扩展(E) mod_rewrite 此指令设置mod_rewrite为了和
RewriteMap
程序通讯而使用的同步锁文件的名称。 在需要使用重写映射表程序(rewriting map-program)时,它必须是一个本地路径(而不能是一个NFS挂接设备)。对其他类型的重写映射表(rewriting map),则无此要求。
- 浏览: 4862318 次
- 性别:
- 来自: 杭州
最新评论
- lehehe: wifi,ip定位,google似乎不能返回数据了,现在我们都 ...
Google WIFI/IP定位技术初探- wx_hello: 求喷码器软件; java程序向喷码器输送字符,喷码器喷出来。 ...
RS232串口 小记- sdt1005: 引用[list][url][flash=200,200][fl ...
GROUP BY 子句及其扩展- a465492689: 太有用了,谢谢分享!
Oracle 表空间- yinren13: 支持视频会议!!我们公司现在就在用视频会议turbomeeti ...
视频会议
评论