|
环境:系统 Windows+Apache 2.21 G9 Y7 u0 D" y7 L- M/ }
7 S# X' E: }+ ?. g% X8 [3 x6 k加载Rewrite模块:! O7 y0 S+ m% z( s5 k( D1 S D- Z
在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。7 ?' V( ?: s; R Z
% b# t# `( ~! n% v f A% t
允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):5 ]4 m) l" L( M# K3 V8 u# K# _
/ s1 t5 l: b4 p2 [# AllowOverride controls what directives may be placed in .htaccess files.
# y5 T$ g; R/ P! ~9 L& |4 O# It can be “All”, “None”, or any combination of the keywords:
: H6 A- Q: m% Y. P7 z1 M# Options FileInfo AuthConfig Limit8 q% y% W/ v0 f' X% g" j9 j+ @3 d
#
0 O& K, M j# R& }* TAllowOverride All/ C. N: A3 f) s; l2 P3 y0 u
( O2 B3 s, E6 ?( O! j& F/ b. h/ @在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。( ^7 D6 t/ r- j! w7 C, z# Y
. x) J) _, p6 R# J8 _/ W/ vApache Rewrite模块的简单应用:
$ a* a" r: b* d1 x/ d6 {Rewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。
+ F, W0 X$ M$ B. p0 B( W* n# ]* _; G1 o9 [8 L" A! R
1、请求跳转+ ^! ]# @ Y% N ]$ ?
目的是如果请求为.jsp文件,则跳转至其它域名访问。
8 W6 e; C7 A- H& j& ~ o例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页
d: M0 A5 e. x7 x" c0 G" a注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。
, V( c. Z1 o x' r4 ~; I6 {修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容
( i7 G# L# L. ~3 u- [- RewriteEngine on$ x- l9 F' |3 z; b0 d
- #开启Rewrite模块% P$ V: i- z" ~2 B& b2 H- C* T3 O
- RewriteRule (.*)\.php$ http://www.xp6.org/$1\.jsp [R=301,L,NC]
复制代码 #截获所有.jsp请求,跳转到http://b.xp6.org/加上原来的请求再加上.php。R=301为301跳转,L为rewrite规则到此终止,NC为不区分大小写
( @& z* c! C3 G0 u9 O9 i2、域名跳转
+ A6 B% M/ Q M5 y9 _如果请求为old.xp6.org下的所有URL,跳转至b.
! M% z( k5 p( {* o" i* _5 B- RewriteEngine on& b! A5 k0 k: Z5 L- T- s* }3 t3 T7 m7 V
- #开启Rewrite模块
& } a4 y+ S/ d1 @ - RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]8 q* {: v+ A1 U d# m9 `% C
- #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符
! d- r+ |# J+ u& c9 n5 H8 g l - RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码 3、防盗链
4 X0 Z0 p" c5 D. m7 g如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容0 L+ L; V8 L- e$ j1 J) T e
- RewriteEngine on
/ `9 ^+ _- w, V( K4 ` - #开启Rewrite模块
! `. m' c7 P' t7 S - RewriteCond %{HTTP_REFERER} !^$: }; d; i. x( x& w# d# _
- #如果不是直接输入图片地址
* M9 x$ ?$ J- w2 x% l3 D - RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]1 p1 a6 K7 O# p( i7 L8 K
- #且如果不是img.xp6.org所有子域名调用的3 E- o- a/ U! j; |
- RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]# s; y* ~+ p* ?! Q) s S7 i9 ^
- RewriteCond %{HTTP_REFERER} !qq.com [NC]6 v: u7 K: o2 U, s
- RewriteCond %{HTTP_REFERER} !google.com [NC]
( g2 R/ T& y& V( [ - RewriteCond %{HTTP_REFERER} !google.cn [NC]
+ Q/ U6 G( C# N b1 m - RewriteCond %{HTTP_REFERER} !baidu.com [NC]: m7 ~4 M' G S7 P
- RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
* B7 e4 f1 m: U* l - 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文件, v- i' O% T" t0 V0 e$ A2 s ^
在Apache2\conf\httpd.conf 最后一行添加+ t$ ^& { B X$ b, D8 u
- RewriteEngine On& u3 y: a0 n5 o" D& K2 Z
- RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码 重启Apache,登陆后台开启全伪) r5 g* |# N& S/ ~" v2 m- Q- Q
+ ]% V% S. {9 M' k x
Linux+Apache环境配置类似。
. i% o! c& Z) V8 l b6 c: t; f9 _) e7 |; K p% [0 c) Q" x S- ~
|
|