|
|
环境:系统 Windows+Apache 2.2: @6 s+ v9 O. _! j. c4 m0 d/ E& h
6 J. p# ^" s# Q% Z加载Rewrite模块:
' x+ X( l( v/ X9 y' c在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。/ T9 d# s4 N- [9 Z1 N
8 b$ N# A5 z; n) |% K$ k* Z0 `5 W8 {允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):
) V* W3 l& e( V7 X! d S" I- I% ?1 M" {3 P& s6 e: }
# AllowOverride controls what directives may be placed in .htaccess files.
+ y+ \$ j! m& d: X& h, L. n# It can be “All”, “None”, or any combination of the keywords:
0 G( I9 r- v* b- B: n/ E# Options FileInfo AuthConfig Limit/ m7 Y5 X& ]! s& i/ ^
#$ N6 C9 i! N4 \" U" ^6 s! B
AllowOverride All
$ n9 U3 \0 h# ?; D9 c/ `6 U, O- P# H# z6 n) H8 W# ]
在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。3 {' c- A2 `2 K
. B7 S, d# G, d W7 \9 B- Z' h, d6 w
Apache Rewrite模块的简单应用:+ x; m( ?6 \/ W8 c7 h5 x
Rewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。
" M3 k8 O* B7 |0 U) z5 [
9 B5 }6 h- F' ]6 L# J8 i1 ^1、请求跳转
' `. P- @/ {3 s( y; n l/ \目的是如果请求为.jsp文件,则跳转至其它域名访问。: n2 }/ o' a( `& T' w( s
例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页, W0 X8 |1 G* R4 R; H# l
注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。
+ p& P/ @# R! D C/ s修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容4 m% l. ` e6 D- E0 \ o
- RewriteEngine on
* F! W) y2 s9 _- E% ]" I& w - #开启Rewrite模块1 M/ j7 o% F6 p: k; ?$ B
- RewriteRule (.*)\.php$ http://www.xp6.org/$1\.jsp [R=301,L,NC]
复制代码 #截获所有.jsp请求,跳转到http://b.xp6.org/加上原来的请求再加上.php。R=301为301跳转,L为rewrite规则到此终止,NC为不区分大小写
" m9 \8 g( L: C$ I7 R; G' A2、域名跳转
/ z7 h2 x3 Q3 M. s+ b: W% U如果请求为old.xp6.org下的所有URL,跳转至b.4 Q4 d% \9 I0 _
- RewriteEngine on
, E! K$ T4 ?- |- J& P; d" c. _7 P9 c - #开启Rewrite模块
% s: E2 |& s6 E& a0 s - RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]
) O; I: |- B" W5 s8 }& X - #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符2 p( Q: m1 X! N! u6 V
- RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码 3、防盗链
2 z' X% a6 `! B. w' f b如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容& D5 W/ G' F5 Y# D# P
- RewriteEngine on0 h4 G( ^( M; S6 x6 g
- #开启Rewrite模块
- o8 |* W) \+ i; X' K8 g# I0 q - RewriteCond %{HTTP_REFERER} !^$
" Z( E: _. b1 l( n; j0 E( z - #如果不是直接输入图片地址
. ]4 L! d c8 b3 V6 B: v2 _ - RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]. j; `. ^6 D. E( A9 _! @
- #且如果不是img.xp6.org所有子域名调用的
5 e7 `' V/ u1 D' O - RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]) u6 K! z. O, Z/ F; a
- RewriteCond %{HTTP_REFERER} !qq.com [NC]
% |9 v& j* l' K( l w - RewriteCond %{HTTP_REFERER} !google.com [NC]
/ f+ m% y" d6 O0 n9 N4 x - RewriteCond %{HTTP_REFERER} !google.cn [NC]
$ Z- [9 B; E( E! C - RewriteCond %{HTTP_REFERER} !baidu.com [NC], C9 _' l3 h: {. T; J
- RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
" a- s' g& i! Q7 J9 l" n - 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文件 h0 p. i* s/ `0 v. d0 C% i0 |
在Apache2\conf\httpd.conf 最后一行添加" N3 N5 f, m4 P5 \( y
- RewriteEngine On
0 ?, U+ X# d# V2 M0 } - RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码 重启Apache,登陆后台开启全伪! j8 M0 c7 }3 r6 a. s
( t( y% e* s# J
Linux+Apache环境配置类似。
' q' \; D! {# h/ _
* Z* U2 G/ N$ r5 |7 m, F( ]' T |
|