搜索
查看: 12025|回复: 1

[网站] Apache如何开启伪静态

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2
' T! n& Z; h$ d9 r
+ A! q! d% J1 H# _加载Rewrite模块:! `" M. ?( d) K7 h
在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。
- t7 ]. ?$ S. E( c5 O* j2 W) x
. E! }( z! W, Q$ k) a1 y允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):
6 b8 p- `# i) A( e* T  S- B2 ]
& `" @1 ^  E3 ^  n, E4 q# AllowOverride controls what directives may be placed in .htaccess files.
, j/ @7 d. {6 f: d) L3 M7 D# It can be “All”, “None”, or any combination of the keywords:, k- a+ s  P, P- Q% o
# Options FileInfo AuthConfig Limit; s, v3 g: _  F' I/ P% T" q' D
#7 [: t8 n7 k- p6 D1 _5 E, V
AllowOverride All1 V- x+ t3 \6 Y, C; }
. T# N! g- W9 ?6 a4 {; k- w  A
在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。: f0 d- z# Q+ L% M: j

6 [# I  j2 Q/ CApache Rewrite模块的简单应用:
9 X3 K/ U" C( M+ ?6 xRewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。
9 Z6 Y" f  b7 j  K" A. c" K" h" x% G& R
) D& ^9 M% G: v9 a7 f/ L1、请求跳转
3 a, r0 l6 P6 F. N  L5 Q目的是如果请求为.jsp文件,则跳转至其它域名访问。, G; t/ X8 R5 S  D
例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页
5 |8 s" K: K: I5 g5 b3 p注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。
- D9 Y/ D" A3 s1 M4 ?) M5 ?' s; I修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容
. B# S, N, z- s
  1. RewriteEngine on
    ) {+ |; t9 A, W- S/ c  Q* s
  2. #开启Rewrite模块
    # t: Q+ O8 p1 o
  3. RewriteRule (.*)\.php$ http://www.xp6.org/$1\.jsp [R=301,L,NC]
复制代码
#截获所有.jsp请求,跳转到http://b.xp6.org/加上原来的请求再加上.php。R=301为301跳转,L为rewrite规则到此终止,NC为不区分大小写* w7 m/ W: ^) H# \) ~+ j
2、域名跳转+ q: h7 B) _0 K) Z  g
如果请求为old.xp6.org下的所有URL,跳转至b./ A% x9 ]* p- V+ \( W+ x0 G
  1. RewriteEngine on' I( _. W+ {$ L$ M' Y0 U6 c0 K
  2. #开启Rewrite模块# D& K5 F( x1 S0 R* M5 A
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC], R0 B5 [; m) x: Q& |/ L
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符
    : K7 Y* z7 [* T, q1 B
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
4 \5 R6 Q* ~9 i; ~# H  o. ^* A如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
: e9 S! H' F/ Q+ s' a8 C: q" m
  1. RewriteEngine on
    ! J$ M% Y/ c- z9 \" m5 O% ~. n  h
  2. #开启Rewrite模块
    6 X' J1 p5 B# O$ O: W
  3. RewriteCond %{HTTP_REFERER} !^$
    $ h+ r+ G( q* _4 P$ m: _& {) M- \
  4. #如果不是直接输入图片地址
    $ E- E& G3 M. \- s
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]
    6 d1 H4 U( R4 D0 G- V4 `& N
  6. #且如果不是img.xp6.org所有子域名调用的
    ) k3 I+ V$ x" H- G) l+ G
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]
    / d8 }# E2 I( h5 C4 n7 U
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]# |9 |3 k! Q2 x; M- P
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]4 e" |) q, @+ @5 U8 ^) u$ p
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]1 n8 \% q$ Z6 k( Y
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]5 }! Y5 b' ^! z( H  I
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
    . \4 a8 e1 o. y/ e) M
  13. 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文件
; q  M4 |, b5 ?) Z在Apache2\conf\httpd.conf 最后一行添加
) ~: E3 H; s' j) p- `/ T; ?
  1. RewriteEngine On
    7 s. l. f  J/ a3 m( n  |1 y2 ?
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪8 I# h* S( D& T* k# U' }) H9 H

; [* k2 m. _- O; jLinux+Apache环境配置类似。/ g" H% ]- O# ?$ {$ L; f

1 A9 U7 X: Q! W: v
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册帐号

本版积分规则

热议作品
精华帖子排行
精彩推荐

虾皮社区,成立十年了!

站长自己也搞不懂想做个什么,反正就是一直在努力的做!

Copyright © 2007-2019 xp6.org Powered by Discuz

QQ|Archiver|手机版|小黑屋|虾皮社区 鲁公网安备 37021102000261号 |网站地图
返回顶部 返回列表