Apache 相干 mod_rewrite ,RewriteCond,{HTTP_HOST}
添加时间:2013-7-1 点击量:
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]
(伪原创)
无论对感情还是对生活,“只要甜不要苦”都是任性而孩子气的,因为我们也不完美,我们也会伤害人。正因为我们都不完美,也因为生活从不是事事如意,所以对这些“瑕疵”的收纳才让我们对生活、对他人的爱变得日益真实而具体。—— 汪冰《世界再亏欠你,也要敢于拥抱幸福》
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]
(伪原创)
无论对感情还是对生活,“只要甜不要苦”都是任性而孩子气的,因为我们也不完美,我们也会伤害人。正因为我们都不完美,也因为生活从不是事事如意,所以对这些“瑕疵”的收纳才让我们对生活、对他人的爱变得日益真实而具体。—— 汪冰《世界再亏欠你,也要敢于拥抱幸福》