搜索
查看: 11627|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2& u3 f6 w3 E+ Q
7 g# y" Z3 u% }5 I
加载Rewrite模块:
' L2 @1 A( L  @4 x% L3 p1 ]在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。0 ?/ v- G8 \; N! [2 {' B+ [/ h6 C
+ N. D6 h5 k5 B5 _4 x1 ]
允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):
: r4 k: U- V+ u0 c! g" c, C; Q- u( N7 v
# AllowOverride controls what directives may be placed in .htaccess files.: O2 A+ N# z$ N' l
# It can be “All”, “None”, or any combination of the keywords:
- ~) @4 d* D% z' q" U8 E# Options FileInfo AuthConfig Limit
7 k4 k; U2 o, N, E: d9 ?9 T. g) {#
4 c% |* O; q3 }9 w; a5 u" ZAllowOverride All, ^0 H- R9 _6 k( q# k

& R  H7 {7 P4 h' B' |在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。- G! O9 N  u  q2 L3 P/ h, r
; E& j* \7 H& E' j
Apache Rewrite模块的简单应用:
8 t. |0 T9 [9 o# ?+ A+ X2 yRewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。! x' j+ ^* q5 W  P# _: r

8 z8 t; O4 A4 v2 g/ u5 }1、请求跳转
3 G( g; c. C& K- ~; f目的是如果请求为.jsp文件,则跳转至其它域名访问。/ z  ~1 p. a& I, r( [9 J
例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页
, L6 ]5 N( _0 r) Y1 s, B注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。3 x  i/ c* R, d# }$ q
修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容* [* k/ o& n) b1 i7 j
  1. RewriteEngine on
    0 |! {7 T# S, |; d  j$ a
  2. #开启Rewrite模块+ i) E2 V- w1 q) x
  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为不区分大小写
* m) b( Z+ ?5 J8 E: B8 d2、域名跳转! [7 P# W- m/ D" m% O& M# x
如果请求为old.xp6.org下的所有URL,跳转至b.8 P$ _' F! f- P# {' I/ h) _
  1. RewriteEngine on
    % r2 t& [9 p5 c8 c6 [
  2. #开启Rewrite模块
    ( ]4 x, ^" P+ m* x& v) K' {+ T
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]! U! W. T: X' d
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符) D8 u% P2 |: x2 i& k
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
# Z1 _. _; v$ P$ H& T3 q! O0 F如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
' }5 `9 e% p' H8 \! W0 Y
  1. RewriteEngine on& C- N! a" d1 n8 f" k* x8 e
  2. #开启Rewrite模块
    " e; h( ?' _7 P3 N! V% J5 J
  3. RewriteCond %{HTTP_REFERER} !^$+ c- Z3 n& T7 X3 c
  4. #如果不是直接输入图片地址
    3 a- D# ^0 @! K* \  a+ D3 B
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]
    7 Y0 v+ ?1 x% e) D* i, ~3 _* J
  6. #且如果不是img.xp6.org所有子域名调用的7 @. C5 L, h* c; h
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]- S- b7 Y5 m' ?; @* o4 G) i1 s
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC], v' q4 T: i5 R2 W
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]
    ) w2 y# u8 F: f/ X7 _& |
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]
    + n' [  Z/ Z0 x) p* M5 y/ C3 x+ r
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]
    + u, S" o5 p' n* M  g3 B
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]& Y9 G. x# q( R2 v* w
  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文件
9 s* b- U* P3 n) o" p在Apache2\conf\httpd.conf 最后一行添加
* ~$ b4 p. K! N) D$ K, f, A
  1. RewriteEngine On
    8 u( Z% t% {. a& K0 }' S
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪4 R+ [, U  z" q; s& @1 ?  t
* |/ `8 [* H2 ?! h8 {  I$ z
Linux+Apache环境配置类似。
1 ]. z* L; D/ X6 k- R
) y  J& ?# j8 t9 {( d) u/ c! q9 U
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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