13 个mod_rewrite 应用举例

1.给子域名加www标记 
RewriteCond %{HTTP_HOST} ^([a-z.]+)?example\.com$ [NC] 
RewriteCond %{HTTP_HOST} !^www\. [NC] 
RewriteRule .? http://www.%1example.com%{REQUEST_URI} [R=301,L] 
这个规则抓取二级域名的%1变量,若是不是以www开始,那么就加www,之前的域名以及{REQUEST_URI}会跟在其后。

2.去掉域名中的www标记 
RewriteCond %{HTTP_HOST} !^example\.com$ [NC] 
RewriteRule .? http://example.com%{REQUEST_URI} [R=301,L]
 

3.去掉www标记,可是保存子域名 
RewriteCond %{HTTP_HOST} ^www\.(([a-z0-9_]+\.)?example\.com)$ [NC] 
RewriteRule .? http://%1%{REQUEST_URI} [R=301,L]
 
这里,当匹配到1%变量之后,子域名才会在%2(内部原子)中抓取到,而咱们须要的正是这个%1变量。 

4.防止图片盗链 
一些站长不择手段的将你的图片盗链在他们网站上,耗费你的带宽。你能够加一下 代码 阻止这种行为。 
RewriteCond %{HTTP_REFERER} !^$ 
RewriteCond %{HTTP_REFERER} !^http://(www\.)?example\.com/ [NC] 
RewriteRule \.(gif|jpg|png)$ - [F] 
若是{HTTP_REFERER}值不为空,或者不是来自你本身的域名,这个规则用[F]FLAG阻止以gif|jpg|png 结尾的URL 
若是对这种盗链你是坚定鄙视的,你还能够改变图片,让访问盗链网站的用户知道该网站正在盗用你的图片。 
RewriteCond %{HTTP_REFERER} !^$ 
RewriteCond %{HTTP_REFERER} !^http://(www\.)?example\.com/.*$ [NC] 
RewriteRule \.(gif|jpg|png)$ 你的图片地址 [R=301,L] 
除了阻止图片盗链 连接 ,以上规则将其盗链的图片所有替换成了你 设置 的图片。 
你还能够阻止特定域名盗链你的图片: 
RewriteCond %{HTTP_REFERER} !^http://(www\.)?leech_site\.com/ [NC] 
RewriteRule \.(gif|jpg|png)$ - [F,L]
 
这个规则将阻止域名黑名单上全部的图片连接请求。 
固然以上这些规则都是以{HTTP_REFERER}获取域名为基础的,若是你想改用成IP地址,用{REMOTE_ADDR}就能够了。

5.若是文件不存在重定向到404页面 
若是你的主机没有提供404页面重定向服务,那么咱们本身建立。 
RewriteCond %{REQUEST_FILENAME} !-f 
RewriteCond %{REQUEST_FILENAME} !-d 
RewriteRule .? /404.php [L] 
这里-f匹配的是存在的文件名,-d匹配的存在的路径名。这段代码在进行404重定向以前,会判断你的文件名以及路径名是否存在。你还能够在404页面上加一个?url=$1参数: 
RewriteRule ^/?(.*)$ /404.php?url=$1 [L]  
这样,你的404页面就能够作一些其余的事情,例如默认信心,发一个邮件提醒,加一个 搜索 ,等等。

6.重命名目录  
若是你想在网站上重命名目录,试试这个: 
RewriteRule ^/?old_directory/([a-z/.]+)$ new_directory/$1 [R=301,L]  
在规则里我添加了一个“.”(注意不是表明得全部字符,前面有转义符)来匹配文件的后缀名。 

7.将.html后缀名转换成.php  
前提是.html文件能继续访问的状况下,更新你的网站连接。 
RewriteRule ^/?([a-z/]+)\.html$ $1.php [L]  
这不是一个网页重定向,因此访问者是不可见的。让他做为一个永久重定向(可见的),将FLAG修改[R=301,L]。 

8.建立无文件后缀名连接  
若是你想使你的 PHP 网站的连接更加简洁易记-或者隐藏文件的后缀名,试试这个: 
RewriteRule ^/?([a-z]+)$ $1.php [L]  
若是网站混有PHP以及HTML文件,你能够用RewriteCond先判断该后缀的文件是否存在,而后进行替换: 
RewriteCond %{REQUEST_FILENAME}.php -f 
RewriteRule ^/?([a-zA-Z0-9]+)$ $1.php [L] 
RewriteCond %{REQUEST_FILENAME}.html -f 
RewriteRule ^/?([a-zA-Z0-9]+)$ $1.html [L]
 
若是文件是以.php为后缀,这条规则将被执行。

9.检查查询变量里的特定参数  
若是在URL里面有一个特殊的参数,你可用RewriteCond鉴别其是否存在: 
RewriteCond %{QUERY_STRING} !uniquekey= 
RewriteRule ^/?script_that_requires_uniquekey\.php$ other_script.php [QSA,L]
 
以上规则将检查{QUERY_STRING}里面的uniquekey参数是否存在,若是{REQUEST_URI}值为script_that_requires_uniquekey,将会定向到新的URL。 

10.删除查询变量  
Apache的mod_rewrite模块会自动辨识查询变量,除非你作了如下改动: 
a).分配一个新的查询参数(你能够用[QSA,L]FLAG保存最初的查询变量) 
b).在文件名后面加一个“?”(好比index.php?)。符号“?”不会在浏览器的地址栏里显示。

11.用新的格式展现当前URI 
若是这就是咱们当前正在运行的URLs:/index.php?id=nnnn。咱们很是但愿将其更改为/nnnn而且让搜索引擎以新格式展示。首先,咱们为了让搜索引擎更新成新的,得将旧的URLs重定向到新的格式,可是,咱们还得保证之前的index.php照样可以运行。是否是被我搞迷糊了? 
实现以上 功能 ,诀窍就在于在查询变量中加了一个访问者看不到的标记符“marker”。咱们只将查询变量中没有出现“marker”标记的连接进行重定向,而后将原有的连接替换成新的格式,而且经过[QSA]FLAG在已有的参数加一个“marker”标记。如下为实现的方式: 
RewriteCond %{QUERY_STRING} !marker 
RewriteCond %{QUERY_STRING} id=([-a-zA-Z0-9_+]+) 
RewriteRule ^/?index\.php$ %1? [R=301,L] 
RewriteRule ^/?([-a-zA-Z0-9_+]+)$ index.php?marker &id=$1 [L]

这里,原先的URL: http://www.example.com/index.php?id=nnnn ,不包含marker,因此被第一个规则永久重定向到 http://www.example.com/nnnn ,第二个规则将 http://www.example.com/nnnn 反定向到 http://www.example.com/index.php?marker &id=nnnn,而且加了marker以及id=nnnn两个变量,最后mod_rewrite就开始进行处理过程。
第二次匹配,marker被匹配,因此忽略第一条规则,这里有一个“.”字符会出如今 http://www.example.com/index.php?marker  &id=nnnn中,因此第二条规则也会被忽略,这样咱们就完成了。
注意,这个 解决 方案要求Apache的一些扩展功能,因此若是你的网站放于在共享主机中会遇到不少障碍。

12.保证安全服务启用  
Apache能够用两种方法辨别你是否开启了安全服务,分别引用{HTTPS}和{SERVER_PORT}变量: 
RewriteCond %{REQUEST_URI} ^secure_page\.php$ 
RewriteCond %{HTTPS} !on 
RewriteRule ^/?(secure_page\.php)$ https://www.example.com/$1 [R=301,L]
 
以上规则测试{REQUEST_URI}值是否等于咱们的安全页代码,而且{HTTPS}不等于on。若是这两个条件同时知足,请求将被重定向到安全服务URI.另外你可用{SERVER_PORT}作一样的测试,443是经常使用的安全服务端口 
RewriteCond %{REQUEST_URI} ^secure_page\.php$ 
RewriteCond %{SERVER_PORT} !^443$ 
RewriteRule ^/?(secure_page\.php)$ https://www.example.com/$1 [R=301,L]

13.在特定的页面上强制执行安全服务 
遇到同一个服务器根目录下分别有一个安全服务域名和一个非安全服务域名,因此你就须要用RewriteCond 判断安全服务端口是否占用,而且只将如下列表的页面要求为安全服务: 
RewriteCond %{SERVER_PORT} !^443$ 
RewriteRule ^/?(page1|page2|page3|page4|page5)$ https://www.example.com/%1[R=301,L] 
如下是怎样将没有设置成安全服务的页面返回到80端口: 
RewriteCond %{ SERVER_PORT } ^443$ 
RewriteRule !^/?(page6|page7|page8|page9)$http://www.example.com%{REQUEST_URI} [R=301,L]
相关文章
相关标签/搜索