URL 重写是将页面映射到本站另外一页面, 而重定向则是将页面映射到另外一主机(域名). 其中临时重定向(R=302)和永久重定向(R=301)都是亲搜索引擎的, 是 SEO 的重要技术. 经过重定向, 浏览器和搜索引擎都意思到页面发生了变化, 从而分别改变地址栏显示的地址和更新搜索引擎索引。php
AllowOverride all Options FollowSysLinks
2.4 如下版本html
RewriteLog "自定义日志路径" # 设置日志等级 RewriteLogLevel 9
2.4 及其以上版本web
在Apache 服务器配置文件中追加:正则表达式
LogLevel alert rewrite:trace3
注意: 日志级别越高, 越影响服务器性能. 生产环境下应关闭重写日志.
RewriteEngineapache
RewriteEngine: 是否启用重写引擎. On启用, Off不启用.
RewriteBaseapi
RewriteBase: 设置重写的基准目录. 基准目录的根目录就是网站的根目录.
RewriteCond浏览器
RewriteCond: 设置重写条件.
RewriteCond TestString CondPattern [flags]
RewriteCond 指令定义一条规则条件。安全
在一条 RewriteRule 指令前面可能会有一条或多条 RewriteCond 指令,只有 TestString 符合 CondPattern 时规则才被应用于当前URL处理。服务器
1) TestString是一个纯文本的字符串,除了包含普通的字符外,还能够包括下列的可扩展结构:cookie
$N: RewriteRule 后向引用,其中(0 <= N <= 9) . $N引用紧跟在 RewriteCond 后面的 RewriteRule 中模板中的括号中的模板在当前 URL 中匹配的数据。
%N: RewriteCond 后向引用, 其中(0 <= N <= 9). %N引用最后一个 RewriteCond 的模板中的括号中的模板在当前 URL 中匹配的数据。
${mapname:key|default}:RewriteMap 扩展。
2) CondPattern是条件 pattern, 即一个应用于当前实例TestString 的正则表达式, 即 TestString 将会被计算而后与CondPattern 匹配. 做为一个标准的扩展正则式, CondPattern 有如下补充:
CondPattern中可使用如下特殊变量:
>CondPattern: 大于, 将 CondPattern 看成一个普通字符串, 将它和 TestString 进行比较, 当T estString 的字符大于CondPattern 为真.=CondPattern: 等于, 将 CondPattern 看成一个普通字符串,将它和TestString进行比较, 当 TestString 与 CondPattern 彻底相同时为真. 若是 CondPattern 只是 "" (两个引号紧挨在一块儿) 此时需 TestString 为空字符串方为真
-d: 是否为目录, 将 TestString 看成一个目录名, 检查它否存在以及是不是一个目录.
-f: 是不是 regular file, 将 TestString 看成一个文件名, 检查它是否存在以及是不是一个 regular 文件.
-s: 是否为长度不为0的 regular文件, 将 TestString 看成一个文件名, 检查它是否存在以及是不是一个长度大于0的 regular 文件.
-l: 是否为 symbolic link, 将 TestString 看成一个文件名, 检查它是否存在以及是不是一个 symbolic link.
-F: 经过 subrequest 来检查某文件是否可访问. 检查 TestString 是不是一个合法的文件, 并且经过服务器范围内的当前设置的访问控制进行访问. 这个检查是经过一个内部 subrequest 完成的, 所以须要当心使用这个功能以下降服务器的性能.
-U: 经过 subrequest 来检查某个 URL 是否存在. 检查 TestString 是不是一个合法的URL, 并且经过服务器范围内的当前设置的访问控制进行访问. 这个检查是经过一个内部 subrequest 完成的, 所以须要当心使用这个功能以下降服务器的性能.
3) [flags]是第三个参数,多个标志之间用逗号分隔。
nocase|NC: 不区分大小写. 在扩展后的 TestString 和 CondPattern 中, 比较时不区分文本的大小写. 注意, 这个标志对文件系统和 subrequest 检查没有影响.
ornext|OR: 创建与下一个条件的或的关系. 默认的状况下,二个条件之间是AND的关系, 用这个标志将关系改成OR. 例如:
RewriteCond %{REMOTE_HOST} ^host1.* [OR] RewriteCond %{REMOTE_HOST} ^host2.* [OR] RewriteCond %{REMOTE_HOST} ^host3.* RewriteRule …
RewriteRule: 设置重写规则.
RewriteRule Pattern Substitution [flags].
1) Pattern是一个做用于当前 URL 的兼容 perl 的正则表达式. 这里的“当前”是指该规则生效时的 URL 的值。
2) Substitution是当原始 URL 与 Pattern 相匹配时, 用以替代(或替换)的字符串. (RewriteRule 中也会进行一次判断, 被捕获的 URL 是否与 Pattern相匹配)
3) Substitution还能够追加特殊标记[flags]做为 RewriteRule 指令的第三个参数。 Flags 是一个包含以逗号分隔的下列标记的列表:
1.redirect|R[=code] (强制重定向 redirect)
强制性执行一个外部重定向. 若是code没有指定, 则默认302. 若是须要使用在 300-400 范围内的其余响应代码, 只需在此指定这个数值便可。
另外, 还可使用下列符号名称之一: temp(默认的), permanent, seeother.
2.forbidden|F(强制 URL 为被禁止的 forbidden )
3.gone|G(强制 URL 为已废弃的 gone )
4.proxy|P(强制为代理 proxy )
此标记使替换成分被内部强制为代理请求, 并当即(重写规则处理当即中断)把处理移交给代理模块. 你必须确保此替换串是一个有效的, 可以为 Apache 代理模块所处理的 URI. 使用这个标记, 能够把某些远程成分映射到本地服务器名称空间, 从而加强了 ProxyPass 指令的功能。
7.chain|C(与下一个规则相连接 chained)
此标记使当前规则与下一个(其自己又能够与其后继规则相连接的, 并能够如此反复的)规则相连接. 它产生这样一个效果: 若是一个规则被匹配, 一般会继续处理其后继规则, 即这个标记不起做用; 若是规则不能被匹配, 则其后继的连接的规则会被忽略. 好比, 在执行一个外部重定向时, 对一个目录级规则集, 你可能须要删除".www" (此处不该该出现".www"的).
8.type|T=MIME-type(强制MIME类型 type)
强制目标文件的MIME 类型为 MIME-type. 好比, 它能够用于模拟 mod_alias 中的 ScriptAlias 指令, 在内部强制被映射目录中的全部文件的 MIME 类型为"application/x-httpd-cgi".
9.nosubreq|NS(仅用于不对内部子请求进行处理 no internal sub-request)
在当前请求是一个内部子请求时, 此标记强制重写引擎跳过该重写规则. 好比, 在 mod_include 试图搜索可能的目录默认文件(http://index.xxx)时, Apache 会在内部产生子请求. 对子请求, 它不必定有用的, 并且若是整个规则集都起做用, 它甚至可能会引起错误. 因此, 能够用这个标记来排除某些规则.
10.nocase|NC(忽略大小写 no case)
它使Pattern 忽略大小写。
11.qsappend|QSA(追加请求串 query string append)
此标记强制重写引擎在已有的替换串中追加一个请求串, 而不是简单的替换. 若是须要经过重写规则在请求串中增长信息, 就可使用这个标记。
12.noescape|NE(在输出中不对URI做转义 no URI escaping)
此标记阻止mod_rewrite 对重写结果应用常规的 URI 转义规则. 通常状况下, 特殊字符(如%, $, ;等)会被转义为等值的十六进制编码. 此标记能够阻止这样的转义, 容许百分号等符号出如今输出中,如:
RewriteRule /foo/(.*) /bar?arg=P1=$1 [R,NE] 可使’/foo/zed’转向到一个安全的请求’/bar?arg=P1=zed’.
13.passthrough|PT(移交给下一个处理器 pass through)
让mod_rewrite 模块将重写的 URL 传回给 Apache 作进一步处理。
14.skip|S=num(跳事后继的规则 skip)
若是知足某指定的条件,则跳事后面第num 调规则。
15.env|E=variable:value(设置环境变量 environment variable)
此标记使环境变量variable 的值为 value, VAL能够包含可扩展的反向引用的正则表达式$N和%N. 此标记能够屡次使用以设置多个变量。这些变量能够在后继的 RewriteCond 指令的pattern 中经过%{ENV:VAR}做引用 。
16.cookie|CO=NAME:VAL:domain[:lifetime[:path]](设置cookie)
在客户端浏览器上设置一个cookie. cookie 的名称是 NAME, 值是 VAL. domain字段是该 cookie 的域, 好比'.apache.org', 可选的 lifetime 是 cookie 生命期的分钟数, 可选的 path 是 cookie 的路径。
RewriteRule重写 URI 后的基准目录也是以.htaccess所在的目录为准. 例如: 访问 http://example.com/foo
RewriteRule ^foo$ bar.php [L]
例1:
<IfModule mod_rewrite.c># 启用rewrite引擎RewriteEngine On# 重写规则: 匹配任意以htm后缀的文件, 将htm替换成php. ^(.*)\.htm$ 是一个正则表达式, 表示须要重写的部分, 此处指以任意字符开头, 以.htm结尾的部分. $1.php 是一个重写规则, $1 表示匹配到正则表达式中第一个子模式的字符串. [NC]: 表示重写规则如何应用, 该处表示不区分大小写. 整条规则即重写以任意字符开头, 以.htm结尾的部分, 重写为由匹配到的第一个子模式字符串和.php拼接成的字符串。RewriteRule ^(.*)\.htm$ $1.php [NC]</IfModule>
IfModule 命令用于判断是否安装了 mod_rewrite 模块。
<IfModule mod_rewrite.c>RewriteEngine On# 设置目录级重写的基准URIRewriteBase /subdir1/RewriteRule ^(.*)\.htm$ $1.php [NC,L,R]</IfModule>
<IfModule mod_rewrite.c><IfModule mod_rewrite.c>RewriteEngine OnRewriteCond %{HTTP_HOST} (localhost:81)RewriteRule ^(.*) http://localhost:82 [R=301]</IfModule>
Nginx 的 URL 重写功能不须要额外的支持. Nginx 自己只支持在服务器配置文件中配置 URL 重写规则, 不支持 .htaccess 文件. 但能够经过在服务器配置文件中引入外部文件的方式, 实现对 .htaccess 文件的支持. 这会严重影响 Nginx 的性能。
rewrite
rewrite regex replacement flag
rewrite ^(.*)\.html$ $1.php last;
if (condition){...}
condition中能够包含以下判断表示:
location ~ \.html$ {if (!-f $request_filename){rewrite (.*)\.html$ $1.php last;}}
return code复制代码
return 403;
location [flags] regex
flags 包括:
rewrite_log on|off
set variable value