|
|
环境:系统 Windows+Apache 2.2
( U4 g6 j+ D7 V: z- p5 J: i+ a% G/ g5 Y
加载Rewrite模块:
* {' J6 X2 _3 j/ e1 v3 T) i在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。
- y' I; u: U- M9 p) h( H" i3 N
}' C% H, O6 y$ x: Q- u: f6 ?4 @0 S允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):$ V1 J, Y, U, J# H% Q
s& _9 h/ b$ U$ m# ?0 O
# AllowOverride controls what directives may be placed in .htaccess files.
& Q) v( o( r- l7 z( m! I2 b; V# It can be “All”, “None”, or any combination of the keywords:! z8 Z9 k( C6 W: X- }
# Options FileInfo AuthConfig Limit
( B T7 U0 `- c4 S9 p! x#) W! N9 X+ m6 G
AllowOverride All
1 p* I8 T- ]" U8 F
! y! G W8 Y# M, |' ^# Y, ^$ ^在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。6 I; p/ P. h+ s" }0 W. \9 w
9 J" u' U1 h& I( |" p" hApache Rewrite模块的简单应用:# I% h( h! @ Z2 Z
Rewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。1 ^& I2 t- g( D/ X6 S. d$ E
. p, j1 ^4 j: r3 n. b" [" V1、请求跳转- ^. S: ]# d0 f
目的是如果请求为.jsp文件,则跳转至其它域名访问。
8 f+ }- i5 k) L5 N) j+ ~( ]5 W例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页# Z* p0 u! @+ m: \9 v4 f# |, J
注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。
y% H. w+ ~" d. M$ X9 E7 V: a修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容2 U: {, c* J) \( X6 `. v" }
- RewriteEngine on
1 s" d3 G% }$ h# e$ x; r/ d: S - #开启Rewrite模块
' S4 ?9 j: R1 Y9 s - RewriteRule (.*)\.php$ http://www.xp6.org/$1\.jsp [R=301,L,NC]
复制代码 #截获所有.jsp请求,跳转到http://b.xp6.org/加上原来的请求再加上.php。R=301为301跳转,L为rewrite规则到此终止,NC为不区分大小写
3 b0 u5 ]/ u; e' ~& i% I* E: U2、域名跳转( l' g# f1 W0 x8 ^" \
如果请求为old.xp6.org下的所有URL,跳转至b.) v9 |2 r3 n* R6 m! i
- RewriteEngine on
: T" Z( F/ S- `/ c5 `, e$ H+ |+ t - #开启Rewrite模块
- \. `- }; C" E! M$ I - RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]8 V9 B6 P- [4 W% R
- #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符
9 P1 E/ v9 H$ ?: m- O& r - RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码 3、防盗链& y& y) f3 M0 o" L* V
如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
8 S3 Z# O% G/ ]+ S1 y- RewriteEngine on2 i, ^3 O f9 }" ~0 l0 v
- #开启Rewrite模块% [+ O5 s# ?+ z' ? f1 a( F5 @
- RewriteCond %{HTTP_REFERER} !^$
2 U1 f* b6 a5 ]& q( n2 H: B - #如果不是直接输入图片地址# Z' a1 z5 J7 e" ?
- RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]5 d# @! a1 F# U* x% F: y
- #且如果不是img.xp6.org所有子域名调用的; x* s: U) {3 Q% M) T
- RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]
9 q* J0 C1 h0 O# O4 Z* G5 k - RewriteCond %{HTTP_REFERER} !qq.com [NC]
1 _' P( N' ]$ f* l5 ` q) m - RewriteCond %{HTTP_REFERER} !google.com [NC]( {# c3 K3 Q( ]4 }" O. w
- RewriteCond %{HTTP_REFERER} !google.cn [NC]/ `1 z/ X1 o. v
- RewriteCond %{HTTP_REFERER} !baidu.com [NC]6 `$ A6 O. I J, D" L5 i
- RewriteCond %{HTTP_REFERER} !feedsky.com [NC]' @( i- q4 d5 D
- RewriteRule (.*)\.(jpg|jpeg|jpe|gif|bmp|png|wma|mp3|wav|avi|mp4|flv|swf)$ http://xp6.org/err.jpg [R=301,L,NC]
复制代码 4、不需要定义.htaccess文件+ \' u& E# B! F
在Apache2\conf\httpd.conf 最后一行添加
4 J. Y: R9 D8 p' E- RewriteEngine On* K& R9 ^( \# c$ E7 T
- RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码 重启Apache,登陆后台开启全伪
6 ~9 f' t D4 i/ s$ a8 c/ V' s) r* [4 {7 T7 `4 n, `
Linux+Apache环境配置类似。
( m; ?$ ?2 {- w! B' K! B8 g% e
% n; i# |/ [1 w1 J+ [% d! [9 y" q | |
|