帖子
查看: 11508|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2
+ ^. p, M8 z$ f. w2 f$ e2 q8 w4 ]1 C9 A/ |5 g0 g, z2 M# W" |
加载Rewrite模块:
0 _% a: M7 u' ]7 E! {. u在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。1 M/ r7 F6 U7 @$ R
3 y+ ]$ b2 |  d' ?) R
允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):
, m5 i" B0 D3 I+ {0 ~$ Y' v" P% Y+ d6 V& |
# AllowOverride controls what directives may be placed in .htaccess files.4 `) k, E( [6 m# R4 e4 M' ]' M
# It can be “All”, “None”, or any combination of the keywords:
, c  V! S% o: E) a# Options FileInfo AuthConfig Limit
2 W0 X8 ^3 P" v" C7 t) H& c$ i#
: m/ l) b& b" t% K: O4 c3 x+ s/ wAllowOverride All
; Z9 R. t2 m+ H: B% V& p$ y
% M6 |6 j: Y& o! V+ I' c: X在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。
, w: S! M% |9 Y' f! z4 n6 P* t- ?
* h8 @7 m5 j$ v. `9 LApache Rewrite模块的简单应用:0 \. q. b9 _; @% m6 o
Rewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。
" d# X2 G0 N" o$ J' W/ Q
* Q) ^1 s- ^" i4 C# {8 E# n1、请求跳转( _; H  B7 B9 J8 L1 v  @
目的是如果请求为.jsp文件,则跳转至其它域名访问。4 z& }/ i" J) U6 o+ L; K* n
例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页, v/ @% Z' O+ `- Q5 z% y) a
注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。# ?) Y1 |" f; h8 v, X. M
修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容7 E' @7 P; p  V! @; m/ ?* J9 h$ z
  1. RewriteEngine on
    / k- w7 Y7 j! |, ?$ D3 j
  2. #开启Rewrite模块& m. q( N9 V  A  n/ H  l' U
  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为不区分大小写5 L& g5 n* u8 c9 Y3 R& z
2、域名跳转
- i$ {% E" F( [( C如果请求为old.xp6.org下的所有URL,跳转至b.1 I5 G$ w7 z! ~2 `' F
  1. RewriteEngine on3 o) e+ p3 M4 C: @
  2. #开启Rewrite模块
    # F/ ]2 P2 ^1 Q' t) q
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]4 F  G1 c, ]( L2 }* G0 X) d6 ]; |* e
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符+ i" v" ]# F: b  s  o) k
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
3 L$ c. l" Z1 G9 I5 V$ A+ I如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
" I" A# G& O' G7 U# @0 O) K) t. Y6 c
  1. RewriteEngine on
    ; n4 F/ e" C4 V9 q( M
  2. #开启Rewrite模块8 n* w! Z( M) `2 w7 y, A9 P0 R
  3. RewriteCond %{HTTP_REFERER} !^$
    ! l0 [% l0 l4 E2 u; ^  q: ^. o
  4. #如果不是直接输入图片地址6 w$ R7 T0 H  r& X9 Q6 e$ `1 d% A/ n
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]' `: F  }+ z1 H- ^) O5 Y! l
  6. #且如果不是img.xp6.org所有子域名调用的$ @6 }6 {# _0 H3 ^0 }
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]
    " b- |9 @$ D6 i  k# d$ V% S
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]
    ' h5 Y8 ~) ?. u. J6 Q, \2 R; p
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]
    ! L8 S/ v/ X( W1 x
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]
    8 ^* J) b4 Z" [, `
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]
    7 ], _/ L7 d$ y  o
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
    5 {2 [; [& ^) v+ w7 }
  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文件3 h! h$ z. L, r: D% G$ B
在Apache2\conf\httpd.conf 最后一行添加
5 Z7 O2 @! P" o# V, C) \/ z
  1. RewriteEngine On, T' f# Y+ F  e1 O3 U
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪
4 o9 y) g1 g( O% o! Y5 T: k' }. n+ x  t! i- t, X
Linux+Apache环境配置类似。4 a$ S$ @% m( c0 p2 u( Y$ e* z

- _- A' e9 A3 {9 T0 \2 k: g( N
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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