【www.gdgbn.com--链接特效】

作为站长,你要决定怎样提高你网页对访问者的辨识度以及在重写的uri地址里放入适当的信息。在创建新的uri规则的时候务必考虑详细周全一些。另外当你完成新的uri规则以后,必须回去更新以前老的链接来匹配新的规则。
当你在设计新的uri规则的时候,一定注意其唯一性。举一个先前的例子,我用了国家名,州省名,城市名作为uri的元素,因为他们在数据库教程里面都是唯一的。但是如果建立一个让用户自己更新的数据库,我们没有理由让用户取的文章名字保持唯一性,所以文章一般在数据库里是以一个自动增长的id作为唯一识别码,这个唯一id对url重写规则相当友好,它可以使你的重写规则更加简洁,在url里面可以用原子非常直接的将其值标识出来。
人们通常想映射数据库里面的值比如标题以及其他字符作为url的标识,在mod_rewrite中有一个rewritemap状态专门处理这种情况,但是前提是你必须有修改apache配置文件httpd.conf的权限。所以为了根本避免这个问题,还是直接用id创建你的链接吧。
空格是以%20的形式展示在url中的,所以你必须在php教程代码里面将其替换掉,php的str_replace函数完全可以胜任这项工作。你只需要在$_get获取查询值的时候,将其替换就可以了。但是在数据库中空格是难免的,所以我宁愿将空格替换成下划线,一下为php代码:
$name = str_replace ( ‘ ‘, ‘_’, $name );
在添加新的url规则的时候,小心不要打破了原先已存在的链接间的相对关系。开发人员通常会惊讶为什么有时候css教程,网页特效,图片等文件出现错误或者不启作用了。记住相对链接只匹配你当前url的地址,所以你需要将这些相对链接更改成绝对链接地址,或者在你的静态网页加上html 标签。
13 个mod_rewrite 应用举例
先前我们举了一个给每个链接加一个www的列子,现在让我们看看用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)$ http://www.example.com/hotlinked.gif [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]

 

本文来源:http://www.gdgbn.com/wangyetexiao/28474/