虽然以前的文章没有了,但我至少得保证原来到域名能够继续访问到新的博客,浏览到新的文章,于是想起用htaccess来做重定向。这次对htaccess的写法做个记录,免得今后还要到处搜罗。
这是我这次用到的几条重定向规则
复制代码 代码如下: RewriteEngine on #silentash全局切换 Rewritecond %{HTTP_HOST} ^(www.)?silentash.com$ [nc] Rewriterule ^(.*)$ $1 [r=301,nc] #blog对应切换 Rewritecond %{HTTP_HOST} ^blog.silentash.com$ [nc] Rewriterule ^(.*)$ [r=301,nc] #app对应切换 Rewritecond %{HTTP_HOST} ^app.silentash.com$ [nc] Rewriterule ^(.*)$ $1 [r=301,nc] #lab对应切换 Rewritecond %{HTTP_HOST} ^lab.silentash.com$ [nc] Rewriterule ^(.*)$ $1 [r=301,nc] #photo对应切换 Rewritecond %{HTTP_HOST} ^photo.silentash.com$ [nc] Rewriterule ^(.*)$ $1 [r=301,nc] #只访问主域的先切换到博客 Rewritecond %{HTTP_HOST} ^()?jb51.net$ [nc] Rewritecond %{REQUEST_URI} ^(/)?$ [nc] Rewriterule ^(.*)$ [r=301,nc]
下面简单解说下上面的意思:
【RewriteEngine On】表示重写引擎开,关闭off,关闭的话当然就不能做转发了。
【Rewritecond %{HTTP_HOST} ^(www.)?silentash.com$ [nc]】 这是重写条件,前面%{HTTP_HOST}表示当前访问的网址,只是指前缀部分,格式是不包括“”和“/”,^表示字符串开始,$表示字符串结尾,.表示转义的. ,如果不转义也行,推荐转义,防止有些服务器不支持,?表示前面括号www.出现0次或1次,这句规则的意思就是如果访问的网址是silentash.com或者就执行以下的语句,不符合就跳过。
【Rewriterule ^(.*)$ $1 [r=301,nc]】 这个根据之前的条件执行相应的规则,在这里的话就是让重定向到jb51.net域下面相应地址,比如来源地址是,前部分的^(.*)$将会匹配当前请求的url,不过这里到底是匹配整个,还是只匹配/abc/1.html即反斜杠后面的成分,还是只匹配abc/1.html?
答案是:根据RewriteBase规则规定,如果rewritebase 为/,将会匹配abc/1.html,默认应该是abc/1.html。后面的$1是正则匹配出来的值,经过组合,之前的url会被重定向为,达到了域名转换的目的。
后面几行大同小异。
还有一个问题是,不能保证每个人输入的网址都是小写的,如果输入大写的呢,linux系统是区分大小写的,所以应该在RewriteCond后添加[NC]忽略大小写的。
下面附上简单的语法规则和flags: 【RewriteCond语法:】 RewriteCond TestString CondPattern [flags] rewritecond的其他用法: ‘-d'(目录) 将TestString视为一个路径名并测试它是否为一个存在的目录。 ‘-f'(常规文件) 将TestString视为一个路径名并测试它是否为一个存在的常规文件。 ‘-s'(非空的常规文件) 将TestString视为一个路径名并测试它是否为一个存在的、尺寸大于0的常规文件。 ‘-l'(符号连接) 将TestString视为一个路径名并测试它是否为一个存在的符号连接。 ‘-x'(可执行) 将TestString视为一个路径名并测试它是否为一个存在的、具有可执行权限的文件。该权限由操作系统检测。 ‘-F'(对子请求存在的文件) 检查TestString是否为一个有效的文件,而且可以在服务器当前的访问控制配置下被访问。它使用一个内部子请求来做检查,由于会降低服务器的性能,所以请谨慎使用! ‘-U'(对子请求存在的URL) 检查TestString是否为一个有效的URL,而且可以在服务器当前的访问控制配置下被访问。它使用一个内部子请求来做检查,由于会降低服务器的性能,所以请谨慎使用!
【RewriteRule语法:】 RewriteRule Pattern Substitution [flags]
【flags】:
‘chain|C'(链接下一规则) 此标记使当前规则与下一个规则相链接。它产生这样的效果:如果一个规则被匹配,则继续处理其后继规则,也就是这个标记不起作用;如果该规则不被匹配,则其后继规则将被跳过。比如,在一个目录级规则中执行一个外部重定向时,你可能需要删除”.www”(此处不应该出现”.www”)。
‘cookie|CO=NAME:VAL:domain[:lifetime[:path]]'(设置cookie) 在客户端设置一个cookie。cookie的名称是NAME,值是VAL。domain是该cookie的域,比如'.apache.org',可选的lifetime是cookie的有效期(分钟),可选的path是cookie的路径。 ‘env|E=VAR:VAL'(设置环境变量) 此标记将环境变量VAR的值为VAL,VAL可以包含可扩展的正则表达式反向引用($N和%N)。此标记可以多次使用以设置多个变量。这些变量可以在其后许多情况下被间接引用,通常是在XSSI(<!–#echo var=”VAR”–>)或CGI($ENV{‘VAR'})中,也可以在后继的RewriteCond指令的CondPattern参数中通过%{ENV:VAR}引用。使用它可以记住从URL中剥离的信息。
‘forbidden|F'(强制禁止URL) 强制禁止当前URL,也就是立即反馈一个HTTP响应码403(被禁止的)。使用这个标记,可以链接若干个RewriteConds来有条件地阻塞某些URL。
‘gone|G'(强制废弃URL) 强制当前URL为已废弃,也就是立即反馈一个HTTP响应码410(已废弃的)。使用这个标记,可以标明页面已经被废弃而不存在了。
‘handler|H=Content-handler'(强制指定内容处理器) 强自制定目标文件的内容处理器为Content-handler。例如,用来模拟mod_alias模块的ScriptAlias指令,以强制映射文件夹内的所有文件都由”cgi-script”处理器处理。
‘last|L'(结尾规则) 立即停止重写操作,并不再应用其他重写规则。它对应于Perl中的last命令或C语言中的break命令。这个标记用于阻止当前已被重写的URL被后继规则再次重写。例如,使用它可以重写根路径的URL(‘/')为实际存在的URL(比如:'/e/www/')。
‘next|N'(从头再来) 重新执行重写操作(从第一个规则重新开始)。此时再次进行处理的URL已经不是原始的URL了,而是经最后一个重写规则处理过的URL。它对应于Perl中的next命令或C语言中的continue命令。此标记可以重新开始重写操作(立即回到循环的开头)。但是要小心,不要制造死循环!
‘nocase|NC'(忽略大小写) 它使Pattern忽略大小写,也就是在Pattern与当前URL匹配时,'A-Z'和'a-z'没有区别。
(编辑:焦作站长网)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|