搜索
查看: 11626|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.24 c/ m: z9 a* L. ^

7 F9 I  z) }5 ?9 `& C% f% X" N加载Rewrite模块:
; _1 d" {9 e4 c8 [" u在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。
4 `& c& M1 u+ q5 B$ w- e( C( C
4 x" ~! O1 o5 W. U. h允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):# e- M$ O7 @5 |& O, n

8 y0 i' _4 I5 _# AllowOverride controls what directives may be placed in .htaccess files.8 x: r  q) ]/ _2 B
# It can be “All”, “None”, or any combination of the keywords:! l/ o4 w+ t" O/ L
# Options FileInfo AuthConfig Limit
: M4 G% [! F9 R, ~' v" B#9 `: j* ^8 b& o+ _* R# u
AllowOverride All
; w7 u9 r3 P2 t2 n; A/ c
- `3 m5 ?( c! {" [$ U1 A# F在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。
( @) j; i% \- A2 I8 z& @( T2 I& m1 [. C) y  W
Apache Rewrite模块的简单应用:
. S5 ?$ O4 Q2 ?1 }Rewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。
: m4 {! S" ~: b6 o# O/ |7 L; l+ O' q6 [2 Q; O
1、请求跳转
1 Q) c* P0 \9 I  ?% y5 q目的是如果请求为.jsp文件,则跳转至其它域名访问。: `0 B# W9 t7 ]: x' U; q( L
例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页8 L/ ]! o% K" O) e2 b9 h8 @
注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。: _5 \) K# O3 m
修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容
- `  ~+ {1 G8 k- E% ~1 \4 M
  1. RewriteEngine on0 Z6 p' C+ x7 ?8 a" j
  2. #开启Rewrite模块
    ( ]+ m8 o4 N: c7 g7 }# Y4 {# \
  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为不区分大小写
% l9 r/ l, m. v/ `2、域名跳转/ b1 c" f) g( E4 t6 a- j0 O
如果请求为old.xp6.org下的所有URL,跳转至b.
& v9 O& J9 j- N9 p0 \
  1. RewriteEngine on
    " O2 J1 B5 U$ C! M6 W
  2. #开启Rewrite模块% w9 W; s. `1 X1 e
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]3 \, M4 q. Z( }* E
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符: B( B. n3 G' @. T
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
& F& e7 U7 n( V) _$ a1 s% V如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
9 o) |! z, [* a" A
  1. RewriteEngine on. ~+ F" C9 {, H: `, _
  2. #开启Rewrite模块
    ( ^, p7 a, P7 U
  3. RewriteCond %{HTTP_REFERER} !^$
    . X- [5 e. Y$ b$ F. `
  4. #如果不是直接输入图片地址4 J# I2 T1 G- z; r) U! X% H
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]
    & k* C- q4 X% W/ o% v$ X  u, d8 h
  6. #且如果不是img.xp6.org所有子域名调用的
    3 Z- Z7 u# u( Q( Q: I7 u7 i. K
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]
    , e- F7 f/ w* i
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]) O) M% J: U- t* P0 |
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]# y- q4 N4 R, M4 }( v  b" Q& Q
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]/ I5 F5 K) E* f2 A5 d, V7 a
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]
    8 E. [4 F. r" u5 p" H' P
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]+ ]! n' ]9 p' U& U& Z
  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文件
7 x1 {& V- n: n8 Q) T/ j2 ^  U: Y在Apache2\conf\httpd.conf 最后一行添加0 n5 J3 ?* w1 }. w9 f0 H: g
  1. RewriteEngine On
    ( I1 D2 v2 J% k  f# A
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪
* f$ h' y- r4 M) `2 r3 S8 l- U! Z% i' W& b4 M* U
Linux+Apache环境配置类似。
" P. ^( }+ \/ C4 ~: _& R# A* w. T' o1 J- N2 x
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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