搜索
查看: 9651|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2* L) N8 P/ Y2 S3 I( s, o4 C: K
3 K7 t* w- W+ l
加载Rewrite模块:- E4 p% u1 h  [
在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。
2 x  Z8 P1 o( U5 `! |$ o0 y% g5 V" G3 T
允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):
6 _0 ^' W' {! Z8 o! T
' k! j! A  I3 x( [# AllowOverride controls what directives may be placed in .htaccess files./ Y* o0 U+ B  ^
# It can be “All”, “None”, or any combination of the keywords:2 v* D) a1 g* b/ r8 L% c. X
# Options FileInfo AuthConfig Limit( W  k" L# `) d
#
+ _( I/ B* R5 H( I/ b0 eAllowOverride All
7 g5 V( U/ Z' S/ q, g5 j4 G4 w0 l" S: @+ E5 k1 ~9 t: i3 N
在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。! \3 }, ^  `4 N4 F* p& u2 n2 c; U% ?

3 Z, N7 {, ~4 s# C9 uApache Rewrite模块的简单应用:1 k6 n; e% {9 J+ H; {; @- Y! o+ D
Rewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。
& Q5 a7 x9 E( a; m- Z( s6 B# ?  y( r% a: _7 K
1、请求跳转, |3 G1 }, ^7 W8 l3 C% B3 d
目的是如果请求为.jsp文件,则跳转至其它域名访问。# ]7 |% i% O5 j; ?8 z& ]
例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页  w4 @$ e: j# X/ t: u4 [5 G# J) G
注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。4 K6 m9 K5 B5 @9 Q3 X
修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容
, Z1 p, K6 q8 ~! a) }
  1. RewriteEngine on
    , y! N$ w* ?: I
  2. #开启Rewrite模块! o$ C8 s- T6 v7 A6 r$ b0 s
  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为不区分大小写0 P  t7 ]0 f; d
2、域名跳转+ J& U- q9 b2 ^0 K. Z
如果请求为old.xp6.org下的所有URL,跳转至b.
" Y6 R! g( {) k/ x8 W4 t, c+ l
  1. RewriteEngine on  v; u$ M  U6 A
  2. #开启Rewrite模块
    $ l& a' [7 }2 o2 q. r. M$ v
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]7 b6 ~2 @- w: `3 F! S. \7 f
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符
    ' w3 @9 k/ a9 [9 I1 `+ c# f
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
- h  |, Q0 J! s9 A$ A  g8 ~4 p9 Q2 S* M如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容7 M  U! @4 _9 r1 c
  1. RewriteEngine on
    8 R, A5 x6 t6 W. I. N
  2. #开启Rewrite模块
    0 E. O3 [% \$ d) ?# R1 D
  3. RewriteCond %{HTTP_REFERER} !^$) q8 x9 D$ Q1 z: Z) W4 B
  4. #如果不是直接输入图片地址0 ]& D+ O4 @' P4 ]
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]6 `! D+ i, _; K5 E! G  @, z6 ^, q
  6. #且如果不是img.xp6.org所有子域名调用的
    9 T/ D) S# _. Z! {1 |& S
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]. J3 a, w8 |6 y4 G9 D
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]4 G9 ^2 B* d# [7 A, a
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]. W, \; ^' t) F- r
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]2 w8 Z9 C, R' q7 I- F/ E
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]! V) z* [- g0 ?; f; B# U
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
    5 a& Q+ ]$ d' O. D# N  e' }
  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文件
) w+ N; D7 w6 Y% Z5 s在Apache2\conf\httpd.conf 最后一行添加
4 L5 _) W: T; H3 x' R, ^/ x
  1. RewriteEngine On- R7 X6 S/ N0 u
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪* Q8 D7 R: w- X, e! ^$ ~9 b! ?

- Q: E& r  Y2 U3 L) B6 LLinux+Apache环境配置类似。
% b% _9 Z0 W% L+ ^7 `7 v7 [5 h  @2 ^/ m( z' @. [( Z5 k+ L1 q* t
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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