搜索
查看: 11431|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2
4 O$ j: e5 h1 P5 F1 }4 c1 q, X) ^- ^' o+ Z4 A4 A; y' g9 @. @5 o
加载Rewrite模块:4 C- w- W/ t" V" m
在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。( R; M8 G" J  X6 f7 s% ~- w/ v
1 C2 f3 T% f) R3 H
允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):! ?7 s" v* C, E: x7 @$ d  _$ X
$ [* s, L' M, W: I8 L) k
# AllowOverride controls what directives may be placed in .htaccess files.8 r' y6 {. R: N" @& p0 p
# It can be “All”, “None”, or any combination of the keywords:
; b5 l* i* u& d; k  F! n0 H$ Q& B# Options FileInfo AuthConfig Limit
1 A' d6 J; k) }8 d#( ]8 s7 M% Y9 |6 O$ T5 t  @
AllowOverride All
" J; N2 l; p; R6 i1 @4 K8 a% o3 X- Z1 C2 x  r9 [8 B
在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。& M6 f/ n% T& R' C5 z

- [. D# n$ a8 rApache Rewrite模块的简单应用:
7 j! L% |' @5 t) [( A# oRewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。7 O) ]- e& Q8 x' Z! T" @: H

. B% O+ v& G. F& I9 k. S. L1、请求跳转2 M- ?3 ]# g. l" d1 C- q+ p
目的是如果请求为.jsp文件,则跳转至其它域名访问。" U& d/ P& B, T' l
例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页+ \( m- y9 e! Y7 }" `" U& h
注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。
. `6 a/ Z' ^" {4 ~) E1 B* T6 L修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容
) m1 j% f) K, g! y" _, `5 ]
  1. RewriteEngine on: I2 t6 f" z, D+ v9 B7 V( g
  2. #开启Rewrite模块& K9 O6 X) S  b+ t6 G4 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为不区分大小写
. t! i5 ]% i0 ^7 I. ]" \) h2、域名跳转
- f$ B  S! {# Y如果请求为old.xp6.org下的所有URL,跳转至b.) A, D; f8 g. `" Z
  1. RewriteEngine on
    / M/ p; q% {) n7 z
  2. #开启Rewrite模块
    ) ~% ]% \. o0 k. ^4 D3 X' b2 o
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]1 H6 s) o, w. x( r
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符
    # a+ z  f. T; |
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
3 \6 A9 _1 F( H8 B6 J9 S如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
* c6 S8 d! E" B9 v
  1. RewriteEngine on/ y# ]4 n# R4 r& o6 e5 B2 W; {
  2. #开启Rewrite模块
    + m- Y$ \3 f4 r
  3. RewriteCond %{HTTP_REFERER} !^$0 f& t+ N/ ~# {, L1 T) [; i
  4. #如果不是直接输入图片地址
    0 v$ j  n. a2 O$ |! A/ |- E
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]  m4 N: f) w; F# b3 Y5 m1 Z
  6. #且如果不是img.xp6.org所有子域名调用的
    " j  n% k' L3 I# Y
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]+ {' N7 R2 F, ?) p* u
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]+ w0 U7 i8 D& b, Z8 [7 r: Y
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]- g* f/ c- r4 M, C; @2 H
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]( l7 _' _$ m* C8 u
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]) F) P; T9 R) |; e; k
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC], `- G) Y6 j! b' t5 T. H5 X* T) k) Y
  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* P, h2 A: F, y
在Apache2\conf\httpd.conf 最后一行添加
6 w7 H1 j2 r) ]# J: k
  1. RewriteEngine On
    # z9 d  A! N  j5 A& i
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪
# N" ~" T# I3 c# _7 \2 v: \2 A* N. d7 x$ b4 Y( W8 O
Linux+Apache环境配置类似。
+ O6 _9 F' L* M0 M( I
# d7 G7 N$ T) e- }* K0 p0 g
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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