cncml手绘网

标题: .htaccess中的apache rewrite规则写法详解 [打印本页]

作者: admin    时间: 2019-1-4 14:36
标题: .htaccess中的apache rewrite规则写法详解

.htaccess中的apache rewrite写法:1 v( L5 ~- W4 l$ p

% p  [, ^' M" f4 c9 O

[size=1em][size=1em]

  1. 3 H6 q6 C6 Q4 `- c
  2. RewriteEngine On# k$ Z+ ~5 X; p6 R. ]6 e
  3. 0 n; ]& C1 ?  d% n5 l' O
  4. RewriteCond %{HTTP_HOST} ^(www\.)?xxx\.com$+ k  o2 j/ Q! ~' _- f4 b! ~2 a6 [# m

  5. 4 V: F, b* f( L, a6 C, V
  6. RewriteCond %{REQUEST_URI} !^/blog/+ h8 B3 ^- N, i& z& A# |

  7. 6 l2 a% T+ i1 ~
  8. RewriteCond %{REQUEST_FILENAME} !-f  [+ |9 P+ q9 b4 w: `" z4 S

  9. # g7 o# V& c" b% e  [, h
  10. RewriteCond %{REQUEST_FILENAME} !-d
    , n& F8 A+ v9 \( ^' \* y

  11. : ?6 W& Q$ y* C/ t! ]. c) U
  12. RewriteRule ^(.*)$ /blog/$1# N  n7 H. j4 H* K

  13. 3 Y4 D2 X4 G# L+ E
  14. # 没有输入文件名的默认到到首页
    5 I7 E0 Y; o& \: s! ?. y( g0 ?0 l! C

  15. 1 v1 a" ^+ G6 q
  16. RewriteCond %{HTTP_HOST} ^(www\.)?xxx\.com$
    * R  c2 d" p  }/ V2 F+ d0 J# p

  17. * n# J, r' N* L$ C2 O- F$ E+ g7 \* }
  18. RewriteRule ^(/)?$ blog/index.php [L]
    & j8 Y) Z! N* N& ]% U& S8 B0 @
复制代码
, J" Y/ I7 v. ?6 ~* \  f

# }, I$ N3 E7 l$ P
9 j+ Y  x4 H* c+ O5 {

, n; m6 d" m8 \7 P9 g
0 R0 L# u: M( L# Q# t, v. @
5 m6 c  }8 x" N9 k

下面我开始解说一下上面的意思:; L6 k  A1 ?1 p+ |. ]& I

6 `9 F2 I0 x# v' R【RewriteEngine On】表示重写引擎开,关闭off,作用就是方便的开启或关闭以下的语句,这样就不需要一条一条的注释语句了。4 L5 B1 k* h7 l4 f# f+ {

, \+ q$ }% Y3 ]5 q' `5 d【RewriteCond %{HTTP_HOST} ^(www\.)?xxx\.com$】
/ X& }6 |7 W: o' H' ]8 ?这是重写条件,前面%{HTTP_HOST}表示当前访问的网址,只是指前缀部分,格式是www.xxx.com不包括“http://”和“ /”,^表示字符串开始,$表示字符串结尾,\.表示转义的. ,如果不转义也行,推荐转义,防止有些服务器不支持,?表示前面括号www\.出现0次或1次,这句规则的意思就是如果访问的网址是xxx.com或者 www.xxx.com就执行以下的语句,不符合就跳过。
) p1 i" K8 X' e- |$ |2 e" @& ?1 R: K8 e- u9 e& x% `
【RewriteCond %{REQUEST_URI} !^/blog/】0 _. d7 R9 M. T6 _- G3 c2 a) V5 v1 R
也是重写条件,%{REQUEST_URI}表示访问的相对地址,就是相对根目录的地址,就是域名/后面的成分,格式上包括最前面的“/”,!表示非,这句语句表示访问的地址不以/blog/开头,只是开头^,没有结尾$/ b( \. t0 |* o$ C2 v

" I; t' y, U! x9 L: S【RewriteCond %{REQUEST_FILENAME} !-f】$ f4 j( L) [4 b& I4 L5 Q
【RewriteCond %{REQUEST_FILENAME} !-d】
' V6 d) O: f8 U$ D' n# D2 t; ]这两句语句的意思是请求的文件或路径是不存在的,如果文件或路径存在将返回已经存在的文件或路径
; G4 A4 i, s# f" J. g7 h4 O) U: \1 x8 X+ ^6 j  p6 B
【RewriteRule ^(.*)$ /blog/$1】重写规则,最重要的部分,意思是当上面的RewriteCond条件都满足的时候,将会执行此重写规则,^(.*)$是一个正则表达的 匹配,匹配的是当前请求的URL,^(.*)$意思是匹配当前URL任意字符,.表示任意单个字符,*表示匹配0次或N次(N>0),后面 /blog/$1是重写成分,意思是将前面匹配的字符重写成/blog/$1,这个$1表示反向匹配,引用的是前面第一个圆括号的成分,即^(.*)$中 的.* ,其实这儿将会出现一个问题,后面讨论。
( n- h( m, Y5 e$ r6 f5 N
9 N' ]" L% s% J: r9 Z2 c4 l1 U【RewriteCond %{HTTP_HOST} ^(www\.)?xxx\.com$】. ]& Z" s2 u. U8 O  ^
【RewriteRule ^(/)?$ blog/index.php [L]】3 O3 t/ F% u# [0 Y! ]4 k$ j$ k
这两句的意思是指请求的host地址是www.xxx.com是,如果地址的结尾只有0个或者1个“/”时,将会重写到子目录下的主页,我猜想这主要因为重写后的地址是不能自动寻找主页的,需要自己指定。
, {6 p# J) a3 D' x* a6 A4 f% e$ M8 h* V7 K6 D# v5 x
现在说说出现的问题,RewriteRule ^(.*)$ /blog/$1前部分^(.*)$将会匹配当前请求的url,例如:请求网址是http://www.xxx.com/a.html,到底是匹配整个 http://www.xxx.com/a.html,还是只匹配/a.html即反斜杠后面的成分,还是只匹配a.html。, E5 a2 ]1 D/ P  O  j9 P
答案是:根据RewriteBase规则规定,如果rewritebase 为/,将会匹配a.html,不带前面的反斜杠,所以上条语句应该写成RewriteRule ^(.*)$ blog/$1(不带/),不过实际应用上带上前面的反斜杠,也可以用,可能带不带都行。现在问题出来了,如果不设置rewritebase 为/ ,将会匹配整个网址http://www.xxx.com/a.html,显然这是错误的,所以应该添加这条:6 ?9 }6 T' Y/ J7 Z4 Q3 B0 h" z. v6 D
RewiteBase /
8 Y/ W# h2 y( Q1 ]! A5 P
8 T: k3 K9 Y: z3 z- |' K; M还有一个问题是,不能保证每个人输入的网址都是小写的,如果输入大写的呢,linux系统是区分大小写的,所以应该在RewriteCond后添加[NC]忽略大小写的。# V# H9 l( i, M% I0 u
至此,完整的语句应该是:7 U/ ^! {# z# j6 T! }4 Y  g
3 `! I3 w9 \$ @

[size=1em][size=1em]
  1. 4 K$ I( `: ^3 ?" V4 U
  2. ####start####+ h; ~4 c0 _, ^$ v" L/ b2 N6 [; E
  3. 8 R  N0 z+ L( A6 y, j7 X
  4. RewriteEngine On
    5 z5 o: J  L# l1 j0 F: y
  5. % l5 w4 l( ~$ y2 N
  6. RewiteBase /
    ! h$ z( \* M0 M% k/ L, Q

  7. 0 B1 n5 o- T+ N2 M6 e
  8. RewriteCond %{HTTP_HOST} ^(www\.)?xxx\.com$ [NC]
    + r# @7 J& z4 I" i# U
  9. 3 b! u5 Q4 L! K3 y
  10. RewriteCond %{REQUEST_URI} !^/blog/
    : W" X) `; g- v& {. J" Y: t

  11. - {, y0 M# I3 [9 u
  12. RewriteCond %{REQUEST_FILENAME} !-f
    9 ?6 \) d1 W, A) @1 U8 e; }$ n/ x

  13. 3 d5 B- L5 [  z' e1 B  Y1 r$ ]; y/ R
  14. RewriteCond %{REQUEST_FILENAME} !-d
    ! L5 ]$ ~9 _8 L3 r8 Q

  15. ) h0 j% W" n; c4 R% V
  16. RewriteRule ^(.*)$ blog/$1
    * z7 U- m; Q  @. F: @2 [
  17. ; U$ D% \1 C" \# s4 s
  18. # 没有输入文件名的默认到到首页9 n2 K0 w8 k1 z* s% r' X
  19. 2 H) b5 I& O+ Z, C& d
  20. RewriteCond %{HTTP_HOST} ^(www\.)?xxx\.com$ [NC]
    $ c9 `$ G; D( I* m% p& w* ]
  21. ; A- \: t( C+ {
  22. RewriteRule ^(/)?$ blog/index.php [L]
    4 K; h1 v9 D9 L" [

  23. ' C8 l# k/ v2 H% K* L( G, g
  24. ####end####
    ( h  W& h4 b- u  N$ o* g2 ]2 z$ p  u0 J
复制代码
# R. e1 f6 {0 b. ^+ T& t) k: d; |
) V$ x; S: |% ]$ A/ ?

4 h' \9 Z$ w+ {, }8 J( ]# b  A
& x* ], H6 _& P! [
4 i: T& [1 N- [8 {* R
5 N3 O7 w! J( f, ~- J  |

如果后面还继续有语句的,就不应该加上最后的[L],因为这是表示最后一条语句的意思
6 _4 I3 Q) M- ^# c9 i: C/ B) z" S. M+ ~
防盗链的语句,同样需要添加RewiteBase /,如下:
1 r* Z: T+ L3 I6 G+ s7 b# Y, }0 ?3 D! x. d+ q8 J: n0 _

[size=1em][size=1em]
  1. 7 S6 W2 S6 L+ y6 v9 W& E# `( [
  2. RewriteEngine on
    9 G8 ]. w! K2 c2 ~- d

  3. , W! G8 `1 I# w7 _4 W; z+ n+ ?& o* |, {
  4. RewiteBase /: o* p+ T- a: \5 ~& J
  5. 0 I- R' m" N0 Z8 T- r  [
  6. RewriteCond %{HTTP_REFERER} !^$ [NC]+ @: l$ T/ U2 ?& _$ I( o- I8 m  V

  7. 9 m+ d( W# ^8 A1 [& |1 k* C5 }6 ]3 [
  8. RewriteCond %{HTTP_REFERER} !xxx.info [NC]8 M! Q+ q' e5 G9 L2 z( X1 Z. u0 N

  9. / Q2 Y. X9 K! ?- M( h$ M& i: c; l, m2 g
  10. RewriteRule \.(jpg|gif|png|bmp|swf|jpeg)$ /error/daolian.gif [R,NC,L]
    ! `3 F' U8 c3 R/ ?. d0 F" B9 g
复制代码
% b; J0 b% e" X4 D

- O8 `1 b1 z5 r! w9 h& j
' K- K' B& q+ k, W+ S+ c* g

- i' E( n0 t, C4 O2 Q7 n

* m$ j! {5 p+ K; L- g
; o1 B: h. m0 `* l4 x: Q

如果后面还继续有语句的,就不应该加上最后的[L],/error/daolian.gif为别人盗链时显示的图片。- x$ n( b# ^' |

0 M' B1 W1 H# C0 k. g下面附上简单的语法规则和flags:
! J0 b# W6 J, c2 @8 Y1 y【RewriteCond语法:】- I- q% Z7 ~* C$ D" ]( O
RewriteCond TestString CondPattern [flags]
* Y! d8 Q- u& mrewritecond的其他用法:, Y5 j0 i# \" i& E
‘-d’(目录)
. b& q, I/ k5 o将TestString视为一个路径名并测试它是否为一个存在的目录。
$ U. t9 n9 V5 k' Z8 E' N‘-f’(常规文件)
6 x, e2 H7 c) T% h将TestString视为一个路径名并测试它是否为一个存在的常规文件。
1 E- K; y: i/ R% _" i‘-s’(非空的常规文件)
& l! V" s0 C; w& s将TestString视为一个路径名并测试它是否为一个存在的、尺寸大于0的常规文件。. X  H0 s3 m+ Z6 t4 A( W+ a/ M
‘-l’(符号连接)
" ?. v, }) X3 c& z/ b2 K4 |, b将TestString视为一个路径名并测试它是否为一个存在的符号连接。
6 q. F$ o/ M* C) @‘-x’(可执行)
5 f3 A$ a9 M6 s3 B4 o4 o) U8 f将TestString视为一个路径名并测试它是否为一个存在的、具有可执行权限的文件。该权限由操作系统检测。
+ }& R5 z5 X; x% m) e‘-F’(对子请求存在的文件)
% c8 L/ t- u( j1 {检查TestString是否为一个有效的文件,而且可以在服务器当前的访问控制配置下被访问。它使用一个内部子请求来做检查,由于会降低服务器的性能,所以请谨慎使用!' B! Z, k* A3 J+ g: C
‘-U’(对子请求存在的URL). [) e1 a7 s" a% m+ {' x* b9 V
检查TestString是否为一个有效的URL,而且可以在服务器当前的访问控制配置下被访问。它使用一个内部子请求来做检查,由于会降低服务器的性能,所以请谨慎使用!" {4 J) ~& e, G' b9 Q4 P2 P& ?( Y( Q
8 R& {3 k9 o& q2 C" h# n
【RewriteRule语法:】6 k0 o* ]# K- F9 X, P% ?
RewriteRule Pattern Substitution [flags]
5 K/ d# `! v; n% K% u9 k
( H; u% B4 ?% U% ~8 a【flags】:
' ~; V2 o" K; D: S4 e1 ^- U. M5 f8 j: }& s/ N
‘chain|C’(链接下一规则)
4 \5 D0 o7 L: ~此标记使当前规则与下一个规则相链接。它产生这样的效果:如果一个规则被匹配,则继续处理其后继规则,也就是这个标记不起作用;如果该规则不被匹 配,则其后继规则将被跳过。比如,在一个目录级规则中执行一个外部重定向时,你可能需要删除”.www”(此处不应该出现”.www”)。# ?) {  u. n+ v8 x
$ \) l3 t8 t1 X3 t7 B
‘cookie|CO=NAME:VAL:domain[:lifetime[:path]]’(设置cookie), U6 \4 `2 {4 R4 A+ [
在客户端设置一个cookie。cookie的名称是NAME,值是VAL。domain是该cookie的域,比如’.apache.org’,可选的lifetime是cookie的有效期(分钟),可选的path是cookie的路径。" b, \3 \3 l- A3 j: K6 S
/ {; ]7 t5 f; i3 R( M* `
‘env|E=VAR:VAL’(设置环境变量)
3 Q$ r! l$ s, O* h! [# S此标记将环境变量VAR的值为VAL,VAL可以包含可扩展的正则表达式反向引用($N和%N)。此标记可以多次使用以设置多个变量。这些变量可 以在其后许多情况下被间接引用,通常是在XSSI(<!–#echo var=”VAR”–>)或CGI($ENV{‘VAR’})中,也可以在后继的RewriteCond指令的CondPattern参数中通过% {ENV:VAR}引用。使用它可以记住从URL中剥离的信息。
0 C3 N9 s5 ?1 s# T4 T1 [0 ?4 [, |/ M' _7 l! l, H
‘forbidden|F’(强制禁止URL)
6 E0 b( g* _2 Q$ q) V强制禁止当前URL,也就是立即反馈一个HTTP响应码403(被禁止的)。使用这个标记,可以链接若干个RewriteConds来有条件地阻塞某些URL。
5 x! {+ j6 ]* v7 y( |, w- k( s% _. R
‘gone|G’(强制废弃URL)
  s5 Q7 {: G' K& L% @强制当前URL为已废弃,也就是立即反馈一个HTTP响应码410(已废弃的)。使用这个标记,可以标明页面已经被废弃而不存在了。
. L! t6 P$ O2 T, ^
- }; `( W+ a; F) u‘handler|H=Content-handler’(强制指定内容处理器)6 G7 V" D6 I3 ]. o
强自制定目标文件的内容处理器为Content-handler。例如,用来模拟mod_alias模块的ScriptAlias指令,以强制映射文件夹内的所有文件都由”cgi-script”处理器处理。
& {7 Z0 M( T& V- g  H
" A3 b4 t* V& i- R* W$ m‘last|L’(结尾规则)0 @, u7 U$ _: K& p1 ^) K3 ?" t# x
立即停止重写操作,并不再应用其他重写规则。它对应于Perl中的last命令或C语言中的break命令。这个标记用于阻止当前已被重写的URL被后继规则再次重写。例如,使用它可以重写根路径的URL(‘/’)为实际存在的URL(比如:’/e/www/’)。- E1 {+ G- K# m& l* o( d- r: b
$ t9 T- v2 y5 Q' l
‘next|N’(从头再来)0 ^, ]8 ?* a+ l8 @) _4 q
重新执行重写操作(从第一个规则重新开始)。此时再次进行处理的URL已经不是原始的URL了,而是经最后一个重写规则处理过的URL。它对应于 Perl中的next命令或C语言中的continue命令。此标记可以重新开始重写操作(立即回到循环的开头)。但是要小心,不要制造死循环!- Z9 `' o' y  R- J" G

9 E  T% @( T! \8 Q5 h! c; k. i‘nocase|NC’(忽略大小写)
4 e* l  o, z) e7 r- w. H! r它使Pattern忽略大小写,也就是在Pattern与当前URL匹配时,’A-Z’和’a-z’没有区别。9 j2 p4 i: {: F- N: J4 M

3 ?) g* S* _- E6 h/ g‘noescape|NE’(在输出中不对URI进行转义)
# s: L6 F4 I3 p5 C/ Y- S此标记阻止mod_rewrite对重写结果应用常规的URI转义规则。 一般情况下,特殊字符(‘%’, ‘$’, ‘;’等)会被转义为等值的十六进制编码(‘%25′, ‘%24′, ‘%3B’等)。此标记可以阻止这样的转义,以允许百分号等符号出现在输出中,比如:3 o/ n- D' z2 X
RewriteRule /foo/(.*) /bar?arg=P1\%3d$1 [R,NE]
  x  ]/ R' p* Q可以使’/foo/zed转向到一个安全的请求’/bar?arg=P1=zed’。
, x# w+ S6 u3 L# m9 X/ N8 r
" R+ i  H4 T' W& @& \- \$ V‘nosubreq|NS’(不对内部子请求进行处理)7 e5 ~: r; p$ e# d  U
在当前请求是一个内部子请求时,此标记强制重写引擎跳过该重写规则。比如,在mod_include试图搜索目录默认文件(index.xxx) 时,Apache会在内部产生子请求。对于子请求,重写规则不一定有用,而且如果整个规则集都起作用,它甚至可能会引发错误。所以,可以用这个标记来排除 某些规则。0 {3 g' `3 h6 v. x  W
使用原则:如果你为URL添加了CGI脚本前缀,以强制它们由CGI脚本处理,但对子请求处理的出错率(或者资源开销)很高,在这种情况下,可以使用这个标记。
, Z, ~' Y7 E* D
" M. @1 i( U5 m: k‘proxy|P’(强制为代理)
+ {# ^8 H$ ?5 x此标记使替换成分被内部地强制作为代理请求发送,并立即中断重写处理,然后把处理移交给mod_proxy模块。你必须确保此替换串是一个能够被 mod_proxy处理的有效URI(比如以http://hostname开头),否则将得到一个代理模块返回的错误。使用这个标记,可以把某些远程成 分映射到本地服务器域名空间,从而增强了ProxyPass指令的功能。4 K" j% I% O2 |( j; e7 s3 w" [; ~
注意:要使用这个功能,必须已经启用了mod_proxy模块。
3 J% l+ N7 o  ?' t- t* d% J& z4 F1 A/ o. L, w* I' \
‘passthrough|PT’(移交给下一个处理器)
  z7 t2 x, D! T7 `" L1 A/ N此标记强制重写引擎将内部request_rec结构中的uri字段设置为filename字段的值,这个小小的修改使得RewriteRule 指令的输出能够被(从URI转换到文件名的)Alias, ScriptAlias, Redirect等指令进行后续处理[原文:This flag is just a hack to enable post-processing of the output of RewriteRule directives, using Alias, ScriptAlias, Redirect, and other directives from various URI-to-filename translators.]。举一个能说明其含义的例子: 如果要将/abc重写为/def, 然后再使用mod_alias将/def转换为/ghi,可以这样:; Y  z6 r! P7 K0 N8 J3 s
RewriteRule ^/abc(.*) /def$1 [PT]' |5 @. h1 d- {2 B
Alias /def /ghi
& O7 q7 a* s' J1 J7 h. s% m如果省略了PT标记,虽然将uri=/abc/…重写为filename=/def/…的部分运作正常,但是后续的mod_alias在试图将URI转换到文件名时会遭遇失效。. h8 |) s1 D  a6 }$ o8 x
注意:如果需要混合使用多个将URI转换到文件名的模块时,就必须使用这个标记。。此处混合使用mod_alias和mod_rewrite就是个典型的例子。3 x; |) S) F! c- D& c

1 r" F, V  L: k% D* G' E2 a‘qsappend|QSA’(追加查询字符串)- }* P# Z" V7 D: v9 y( Z* Q3 ?
此标记强制重写引擎在已有的替换字符串中追加一个查询字符串,而不是简单的替换。如果需要通过重写规则在请求串中增加信息,就可以使用这个标记。
8 r+ R8 K4 X* p& `7 r9 M8 I; }8 D8 Q8 _& }5 U# ^9 G5 a* \) k
‘redirect|R [=code]‘(强制重定向)
* K4 p5 D& @+ }2 j1 r若Substitution以http://thishost[:thisport]/(使新的URL成为一个URI)开头,可以强制性执行一个 外部重定向。如果没有指定code,则产生一个HTTP响应码302(临时性移动)。如果需要使用在300-400范围内的其他响应代码,只需在此指定即 可(或使用下列符号名称之一:temp(默认), permanent, seeother)。使用它可以把规范化的URL反馈给客户端,如将”/~”重写为”/u/”,或始终对/u/user加上斜杠,等等。3 w$ W7 |) r, v* r* M/ v3 f7 ?& F4 M
注意:在使用这个标记时,必须确保该替换字段是一个有效的URL。否则,它会指向一个无效的位置!并且要记住,此标记本身只是对URL加上 http://thishost[:thisport]/前缀,重写操作仍然会继续进行。通常,你还会希望停止重写操作而立即重定向,那么就还需要使 用’L'标记。
3 @$ u  G, T( O: w4 w( R$ z( y3 [0 \' W4 G) M8 \
’skip|S=num’(跳过后继规则)/ |9 d' ~) `# w- L
此标记强制重写引擎跳过当前匹配规则之后的num个规则。它可以模拟if-then-else结构:最后一个规则是then从句,而被跳过的skip=N个规则是else从句。注意:它和’chain|C’标记是不同的!
8 o1 }4 |2 k4 p4 d/ c& V' x# l2 G- H) c6 G- G0 x/ k
‘type|T=MIME-type’(强制MIME类型)
% `8 W+ U! y4 L$ G* e强制目标文件的MIME类型为MIME-type,可以用来基于某些特定条件强制设置内容类型。比如,下面的指令可以让.php文件在 以.phps扩展名调用的情况下由mod_php按照PHP源代码的MIME类型(application/x-httpd-php-source)显 示:7 C  A4 Z4 U8 B$ r
RewriteRule ^(.+\.php)s$ $1  [T=application/x-httpd-php-source]7 J9 M) H3 w  ~4 p


# R/ p  x& S& t  V. C5 n

如果熟练掌握rewrite规则的编写,能够加强对网站URL的控制,对用户体验、SEO都十分有利。

7 S" E+ ]3 k5 g5 `, U8 n

一、防盗链功能: o+ f7 A5 x) a& H7 i! h2 k5 \

[size=1em][size=1em]

  1. + L: x& [  @) U/ @/ U/ \1 R2 R9 ~5 H3 B
  2. RewriteEngine On9 ~3 C5 q1 c, H6 z6 ~, Y

  3. # E. H) z5 m% o) N5 w
  4. RewriteCond %{HTTP_REFERER} !^http://(.+.)?mysite.com/ [NC]
    9 s, i1 g7 B7 ^  u" X& p# k1 D
  5. ( \7 n4 X$ @1 a  x/ b+ @
  6. RewriteCond %{HTTP_REFERER} !^$! b2 [: f/ H+ ?8 U6 K' E5 E  u

  7. + X5 |- T5 `' C$ }
  8. RewriteRule .*.(jpe?g|gif|bmp|png)$ /images/nohotlink.jpg [L]
    6 s# b# I* f$ S! ?# E
复制代码
9 a! E$ G% ?3 b7 e7 v5 T6 S
# N7 M7 c# R( _& g

0 R% s! O/ H8 S7 Y
5 A4 u' _* a6 ?( m' c" H% K, F

4 w. Q0 p: @, {3 n: D% f
  o. T( v+ J. d  g+ {" O1 ]

逐行讲解一下:

3 }# U% `. t# b  n

1.打开Rewrite功能。有可能服务器设置里已经是全局下打开了,但是多写也没事。

2.RewriteCond指令,定义生效条件,用于寻找匹配条件的地址。后面内容用正则表达式匹配。代表含义是发送的请求不由mysite.com而来,那就是盗链啦。末尾的[NC]代表忽略大小写。

3.发送请求的主机前缀不为空。

4.RewriteRule指令,定义重写规则,把匹配的地址按此规则重写。本例中把这些后缀为这些图片格式的,都替换到某一个图片下。[L]表示这是最后一段规则。

+ s8 l# F9 b) v$ r  O2 J

只这四行就实现了防盗链是不是很神奇,编写起来是不是又觉得复杂。

这里总结了几个常用参数(不是全部):

' w/ c* ]4 p. h! ?8 j

RewriteCond下:

[NC] 不分字母大小写

[OR] 用于连接下一条规则


+ b9 Q' Z) x$ |5 L+ N# G

RewriteRule下:

[R] 强制重定向,[R=code] code默认为302

[F] 禁用URL,返回HTTP 403 错误

[L] 这是最后一条规则,之后内容无用


: g  s0 \' j( Y

还有一篇关于正则表达式的教程(很详细):

http://www.unibetter.com/deerchao/zhengzhe-biaodashi-jiaocheng-se.htm
  N9 I# E" X* ^6 P2 v( @* E+ X

二、网址规范化

[size=1em][size=1em][size=1em]
  1. 8 r! C; A9 y& ^# ^) x
  2. Options +FollowSymLinks
    5 ~6 q1 u1 g- q: l* U5 r
  3. 0 Q/ _. Z* i  x# b& O7 C
  4. rewriteEngine on
    - ]! T/ e5 S1 P) O0 Y8 _* Q' q! {5 X: q2 X
  5. 7 F8 r$ F4 t. {  O- P6 r; J0 {
  6. rewriteCond %{http_host} ^yourdomain.com [NC]
      N, V0 T) H: w: P
  7. 4 l8 r3 @9 v; o
  8. rewriteRule ^(.*)$ http://www.yourdomain.com/$1 [R=301,L]  X/ |; \2 O' _; ?0 D3 x
复制代码

( O6 a( q6 i% v: i& x) O
  P, `* W6 a3 S# t6 z

9 ]3 {8 ]; Q6 R1 {: Y4 x. f
0 r3 F* s, N; H9 i' l- Z+ ]" D
+ Z4 O% D9 n: I; Z
  t9 t- p4 s: d' q* X& Q5 u* N

这个是把所有二级域名都重定向到www.yourdomain.com的例子,现在看来是不是很简单了?

需要注意的是,这里的Options +FollowSymLinks不是必须的,但在某些服务器如果不设置FollowSymLinks,可能引起500错误。


* _( Z1 t6 r3 q! z0 S9 E

再来看一个好玩的重定向,把google蜘蛛指向某个网站

[size=1em][size=1em][size=1em]

  1. 0 I% k( c: T* ?1 T  a; [
  2. RewriteEngine On
    % M0 [1 ]9 _" N4 w0 c
  3. # {& F: C' {9 w* p. c* W9 ]6 [& H
  4. RewriteBase /) F) `$ Q# t- I+ A+ H
  5. 3 u9 m; t" t- O1 u2 M# @# t5 x( R1 g
  6. RewriteCond %{HTTP_USER_AGENT} (Googlebot)
    3 l6 n! K+ F/ G7 X3 h0 o

  7. ' j' N/ X: D' K( ]
  8. RewriteRule ^ http://abc.com/ [R=301,L]. b: A' E3 \6 z
复制代码
9 t! D8 |& O. I# E7 X. F) _, U

' b: s6 {0 N6 h- }8 k: d4 O
* j; C& h) v* q. n' o" }& ?

5 ?& Q( D5 U5 t9 f# V! ^' X) a) C0 A

. @: ?& n# i5 B! K0 A& j6 q

1.打开Rewrite功能。

2.RewriteBase指令,设置目录级重写的基准URL。可以理解成把该目录(这个.htaccess所在目录)假定为基准的URL前缀。本例中这样的写法无用。

3.RewriteCond指令。匹配所有USER_AGENT为Googlebot的发送请求。

4.RewriteRule指令。本例中把这些请求都重定向到了abc.com。

2 X( I5 ?9 f1 o# U4 b1 Z" E$ L2 I

在本例中,这个配置应该是黑客所为,把google蜘蛛指向某个网站,等于伪造PR。

% V/ t; b5 u# p

三、临时错误页面


2 L- D3 }# C3 U5 Z8 S/ `- c

当你的网站在升级、修改的时候,你最好让访客转到指定的页面,而不是没做完的页面或者是错误页。

这时我们做一个302转跳就好。

[size=1em][size=1em][size=1em]

  1. , ]' ~8 c2 I. M( X# d8 T/ d; o8 ~# f
  2. RewriteEngine on
    % J7 A& h+ C# |( F
  3. 5 V! u! \# L2 _; U" D/ t
  4. RewriteCond %{REQUEST_URI} !/maintenance.html$
    5 z! o! d% {4 V: W" z# n, \

  5. 6 l% d: N! r% E: Y/ e- L
  6. RewriteCond %{REMOTE_ADDR} !^123.123.123.1230 G8 q; ~3 m; z; c5 A: @3 n% J: k

  7. - ^4 }# [! Y/ T- g7 B
  8. RewriteRule $ /error.html [R=302,L]
    $ T; H2 U0 q1 r
复制代码
: J' V: _( p' `
1 F  |' G/ ?/ w2 D; ^1 Q
4 x4 Z1 p8 l/ P

/ m2 |" a0 h* J2 i6 m
7 }) w1 ]3 x, q$ C" D- x9 ]
" P: E: h, E% C7 g8 z, a  m

1.继续打开Rewrite功能。

2.REQUEST_URI,请求的URL值。这里指所有访问maintenance.html页面的请求。

3.REMOTE_ADDR,向服务器发送请求的IP地址。本例中此处应设为你自己的IP,这样就只有你能访问。

4.RewriteRule指令。本例中把这些请求都重定向到了error.html 。


( T" A5 e6 S& Z3 `% \, B

在本例,我们总结几个常用的正则表达式和特殊符号。

2 t' c( g, q5 b1 v

(.*) 用于匹配某一区域内所有内容。如 abc/def/ghi 可用 (.*)/(.*)/(.*) 匹配。

([a-zA-Z_]+) 匹配英文单词,允许用-和_连接。

([0-9]+) 匹配多位数字,通常用于匹配ID。

([0-9]) 只匹配一位的数字。

# `' s& l* z& G( {

^ 表示正则的开始

$ 表示正则的结束


% I+ h" N* q1 P' \  Z' h  v

四、重定向RSS地址到Feedburner


* p$ g7 q! y4 y/ f7 Z3 q7 L  Z( l

除了可以更改模板里的RSS地址外,.htaccess也能实现RSS地址的更改,并更加方便。

[size=1em][size=1em][size=1em]
  1. 0 x+ Q& R( y- B0 h5 Y
  2. RewriteEngine on
    ' I9 d5 X- C7 F

  3. * B- X! `, u; R* Y1 N
  4. RewriteCond %{HTTP_USER_AGENT} !FeedBurner    [NC]
    2 `3 V, L0 U* Y, V- y' {
  5. ; Z6 `- ^4 t$ i
  6. RewriteCond %{HTTP_USER_AGENT} !FeedValidator [NC]( }/ @: F( u# Z5 h! d( k
  7.   p4 ]8 Y8 P- |' N8 f9 Q
  8. RewriteRule ^feed/?([_0-9a-z-]+)?/?$ http://feeds2.feedburner.com/yourname [R=302,NC,L]5 _8 R% R2 v( u' {0 H( s' Z
复制代码
# I5 L2 @5 b) z0 i5 Q, {
8 o4 L: s$ p9 i
, X) c7 L0 x4 t& j5 s- I

" t- X- [" O8 `6 P4 `& T4 b+ o/ K4 s  r0 {& h
+ n/ W; ^0 ~$ Z# w& Q: v

有了上面的总结,本例其实就很简单了吧。

唯一要注意的是这样操作要确保填写正确的HTTP_USER_AGENT。其实你不常换模板的话。。可能还是直接改模板更省事。


2 U+ ~9 P4 [6 z

在最后,推荐几个好东东:

在线.htaccess生成器:htaccessEditor http://www.htaccesseditor.com/sc.shtml

mod_rewrite模块中文参考手册:http://man.chinaunix.net/newsoft/Apache2.2_chinese_manual/mod/mod_rewrite.html


6 u6 v4 h; h/ C& ?3 V7 q; n. `
* X2 I5 O/ _- F: C% w% e+ ^2 i




欢迎光临 cncml手绘网 (http://www.cncml.com/) Powered by Discuz! X3.2