apache的rewrite规则使用说明
rewrite标志
r[=code](force redirect) 强制外部重定向
强制在替代字符串加上http://thishost[:thisport]/前缀重定向到外部的url.如果code不指定,将用缺省的302 http状态码。
f(force url to be forbidden)禁用url,返回403http状态码。
g(force url to be gone) 强制url为gone,返回410http状态码。
p(force proxy) 强制使用代理转发。
l(last rule) 表明当前规则是最后一条规则,停止分析以后规则的重写。
n(next round) 重新从第一条规则开始运行重写过程。
c(chained with next rule) 与下一条规则关联
如果规则匹配则正常处理,该标志无效,如果不匹配,那么下面所有关联的规则都跳过。
t=mime-type(force mime type) 强制mime类型
ns (used only if no internal sub-request) 只用于不是内部子请求
nc(no case) 不区分大小写
qsa(query string append) 追加请求字符串
ne(no uri escaping of output) 不在输出转义特殊字符
例如:rewriterule /foo/(.*) /bar?arg=p1\%3d$1 [r,ne] 将能正确的将/foo/zoo转换成/bar?arg=p1=zed
pt(pass through to next handler) 传递给下一个处理
例如:
rewriterule ^/abc(.*) /def$1 [pt] # 将会交给/def规则处理
alias /def /ghi
s=num(skip next rule(s)) 跳过num条规则
e=var:val(set environment variable) 设置环境变量
rewrite时服务器变量:
http headers:http_user_agent, http_referer, http_cookie, http_host, http_accept
connection & request: remote_addr, query_string
server internals: document_root, server_port, server_protocol
system stuff: time_year, time_mon, time_day
rewrite规则表达式的说明:
. 匹配任何单字符
[chars] 匹配字符串:chars
[^chars] 不匹配字符串:chars
text1|text2 可选择的字符串:text1或text2
? 匹配0到1个字符
* 匹配0到多个字符
+ 匹配1到多个字符
^ 字符串开始标志
$ 字符串结束标志
\n 转义符标志
反向引用 $n 用于 rewriterule 中匹配的变量调用(0 < = n <= 9)
反向引用 %n 用于 rewritecond 中最后一个匹配的变量调用(1 <= n <= 9)
rewritecond标志符
'nocase|nc'(no case)忽略大小
'ornext|or' (or next condition)逻辑或,可以同时匹配多个rewritecond条件
rewriterule适用的标志符
'redirect|r [=code]' (force redirect)强迫重写为基于http开头的外部转向(注意url的变化) 如:[r=301,l]
'forbidden|f' (force url to be forbidden)重写为禁止访问
'proxy|p' (force proxy)重写为通过代理访问的http路径
'last|l' (last rule)最后的重写规则标志,如果匹配,不再执行以后的规则
'next|n' (next round)循环同一个规则,直到不能满足匹配
'chain|c' (chained with next rule)如果匹配该规则,则继续下面的有chain标志的规则。
'type|t=mime-type' (force mime type)指定mime类型
'nosubreq|ns' (used only if no internal sub-request)如果是内部子请求则跳过
'nocase|nc' (no case)忽略大小
'qsappend|qsa' (query string append)附加查询字符串
'noescape|ne' (no uri escaping of output)禁止url中的字符自动转义成%[0-9]+的形式。
'passthrough|pt' (pass through to next handler)将重写结果运用于mod_alias
'skip|s=num' (skip next rule(s))跳过下面几个规则
'env|e=var:val' (set environment variable)添加环境变量
实际操作
例子:
rewriteengine on
rewritecond %{http_user_agent} ^msie [nc,or]
rewritecond %{http_user_agent} ^opera [nc]
rewriterule ^.* - [f,l] 这里”-”表示没有替换,浏览器为ie和opera的访客将被禁止访问。
例子:
rewriteengine on
rewritebase /test
rewritecond %{request_filename}.php -f
rewriterule ([^/]+)$ /test/$1.php
#for example: /test/admin => /test/admin.php
rewriterule ([^/]+)\.html$ /test/$1.php [l]
#for example: /test/admin.html => /test/admin.php
限制目录只能显示图片
< ifmodule mod_rewrite.c>
rewriteengine on
rewritecond %{request_filename} !^.*\.(gif|jpg|jpeg|png|swf)$
rewriterule .*$ – [f,l]
< /ifmodule>
推荐阅读
-
Apache Rewrite实现URL的301跳转和域名跳转
-
apache 开启重定向 rewrite的实现方法
-
WordPress在window2003 IIS ISAPI ReWrite下的URL规则
-
Apache伪静态规则文件.htaccess的另类用法
-
浅析Apache中RewriteCond规则参数的详细介绍
-
apache的rewrite规则使用说明
-
13个实用的Apache Rewrite重写规则
-
Discuz 7.0伪静态ReWrite的.htaccess规则
-
如何在Ubuntu下启动Apache的Rewrite功能
-
利用.htaccess的Rewrite规则实现Discuz论坛的伪静态链接