搜索
查看: 11862|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2: @6 s+ v9 O. _! j. c4 m0 d/ E& h

6 J. p# ^" s# Q% Z加载Rewrite模块:
' x+ X( l( v/ X9 y' c在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。/ T9 d# s4 N- [9 Z1 N

8 b$ N# A5 z; n) |% K$ k* Z0 `5 W8 {允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):
) V* W3 l& e( V7 X! d  S" I- I% ?1 M" {3 P& s6 e: }
# AllowOverride controls what directives may be placed in .htaccess files.
+ y+ \$ j! m& d: X& h, L. n# It can be “All”, “None”, or any combination of the keywords:
0 G( I9 r- v* b- B: n/ E# Options FileInfo AuthConfig Limit/ m7 Y5 X& ]! s& i/ ^
#$ N6 C9 i! N4 \" U" ^6 s! B
AllowOverride All
$ n9 U3 \0 h# ?; D9 c/ `6 U, O- P# H# z6 n) H8 W# ]
在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。3 {' c- A2 `2 K
. B7 S, d# G, d  W7 \9 B- Z' h, d6 w
Apache Rewrite模块的简单应用:+ x; m( ?6 \/ W8 c7 h5 x
Rewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。
" M3 k8 O* B7 |0 U) z5 [
9 B5 }6 h- F' ]6 L# J8 i1 ^1、请求跳转
' `. P- @/ {3 s( y; n  l/ \目的是如果请求为.jsp文件,则跳转至其它域名访问。: n2 }/ o' a( `& T' w( s
例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页, W0 X8 |1 G* R4 R; H# l
注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。
+ p& P/ @# R! D  C/ s修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容4 m% l. `  e6 D- E0 \  o
  1. RewriteEngine on
    * F! W) y2 s9 _- E% ]" I& w
  2. #开启Rewrite模块1 M/ j7 o% F6 p: k; ?$ B
  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为不区分大小写
" m9 \8 g( L: C$ I7 R; G' A2、域名跳转
/ z7 h2 x3 Q3 M. s+ b: W% U如果请求为old.xp6.org下的所有URL,跳转至b.4 Q4 d% \9 I0 _
  1. RewriteEngine on
    , E! K$ T4 ?- |- J& P; d" c. _7 P9 c
  2. #开启Rewrite模块
    % s: E2 |& s6 E& a0 s
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]
    ) O; I: |- B" W5 s8 }& X
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符2 p( Q: m1 X! N! u6 V
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
2 z' X% a6 `! B. w' f  b如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容& D5 W/ G' F5 Y# D# P
  1. RewriteEngine on0 h4 G( ^( M; S6 x6 g
  2. #开启Rewrite模块
    - o8 |* W) \+ i; X' K8 g# I0 q
  3. RewriteCond %{HTTP_REFERER} !^$
    " Z( E: _. b1 l( n; j0 E( z
  4. #如果不是直接输入图片地址
    . ]4 L! d  c8 b3 V6 B: v2 _
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]. j; `. ^6 D. E( A9 _! @
  6. #且如果不是img.xp6.org所有子域名调用的
    5 e7 `' V/ u1 D' O
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]) u6 K! z. O, Z/ F; a
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]
    % |9 v& j* l' K( l  w
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]
    / f+ m% y" d6 O0 n9 N4 x
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]
    $ Z- [9 B; E( E! C
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC], C9 _' l3 h: {. T; J
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
    " a- s' g& i! Q7 J9 l" n
  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文件  h0 p. i* s/ `0 v. d0 C% i0 |
在Apache2\conf\httpd.conf 最后一行添加" N3 N5 f, m4 P5 \( y
  1. RewriteEngine On
    0 ?, U+ X# d# V2 M0 }
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪! j8 M0 c7 }3 r6 a. s
( t( y% e* s# J
Linux+Apache环境配置类似。
' q' \; D! {# h/ _
* Z* U2 G/ N$ r5 |7 m, F( ]' T
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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