搜索
查看: 12158|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2
/ z- b) r) l) I/ E9 [/ O, R& M
9 q; t5 B  D' `# M( U" j加载Rewrite模块:+ o& v: q% L0 g+ b! g; t
在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。3 P& a. R' r9 k  P8 |

  o+ E$ z3 t% C- U  f允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):
  Q+ @8 F1 e& T
1 A  v  ^) d3 y  ]5 g# [# AllowOverride controls what directives may be placed in .htaccess files.
7 g" n+ ]' u, c+ z: E% n# It can be “All”, “None”, or any combination of the keywords:
# ~% i0 u' S( G& s# Options FileInfo AuthConfig Limit5 h& G4 E6 v' L: J, T0 A+ Y$ r
#
. i% h+ T9 P% ?2 q$ {8 NAllowOverride All4 O$ |' _: G; j$ s; r! O9 U8 k
% X, [- F4 P7 |& S) }1 ^
在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。
8 L! v. P5 K8 n* \5 s
! G- q: M. b% B! DApache Rewrite模块的简单应用:
8 P, I, c6 x) O: ERewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。
  J8 A9 I) R6 e' |6 n8 M0 I8 \$ g: Y) `- B7 x+ G" ~7 {
1、请求跳转8 c+ T6 ^2 d9 \! E! _) S
目的是如果请求为.jsp文件,则跳转至其它域名访问。
$ t! X4 c7 q9 a7 k& s+ i例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页
2 J* u" ?3 F' E注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。3 M- d% r+ r) j0 f& T' L
修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容
; W, m, V7 O3 T+ T) b
  1. RewriteEngine on
    ! x- {7 \1 m8 E: g
  2. #开启Rewrite模块$ |/ n* }) F4 O" p9 H/ 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为不区分大小写4 [( C" ^# j7 x0 T$ {. q4 k! s. f
2、域名跳转
3 V% Z- ~8 {- v* |" M& ^如果请求为old.xp6.org下的所有URL,跳转至b., D9 l) C8 B6 Y6 j# X- Q) d
  1. RewriteEngine on
    9 d" e: P7 u, u7 K- R# ]5 d( I
  2. #开启Rewrite模块
    : x/ s; S1 k  F+ D: R2 `. U9 ~$ @8 _
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]2 `* n5 ^; y3 Z4 V' [0 F
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符; Y9 E/ D) R$ W
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
6 g* e2 d( X9 m% z6 W4 v- Y如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
$ I) H: b' ~- {+ S& G
  1. RewriteEngine on
    2 I1 ^+ c3 W8 E4 H8 _" z9 A
  2. #开启Rewrite模块0 I' i# ]& I2 {$ s% D
  3. RewriteCond %{HTTP_REFERER} !^$
    : f2 b8 ^- i: m- |0 {
  4. #如果不是直接输入图片地址/ q) {6 f2 J+ \8 m
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]
    % I# J1 V3 X+ u
  6. #且如果不是img.xp6.org所有子域名调用的
    ' x. l0 f  Z3 g, J
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]; q9 f0 a, V; }: ^+ h. m6 W5 v
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]
    " j: o' ?+ P1 |
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]
    9 [/ U5 g' n. f
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]
      ^' U0 i; s8 ^+ X% X
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]
    0 R0 h4 {6 ^+ Q
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
    : a" T7 L. N1 a
  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文件
# z% B0 }( d5 K) j! I' Q/ S. R在Apache2\conf\httpd.conf 最后一行添加- t+ H: p5 l4 ]
  1. RewriteEngine On& x9 T, a# d/ X8 s: Q
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪
1 G2 P% D: q0 p( Y/ }* F3 e5 }  }% y" B' q/ r, M; b: @( o1 D
Linux+Apache环境配置类似。: k) z3 B5 g, U

1 u: K& h. X2 L/ O* v/ B
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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