搜索
查看: 11875|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2' l6 s4 G1 O" V: Y0 I. J* _. t
) I! K4 Q7 y" _1 g
加载Rewrite模块:
: ^; b% d. `2 @; N在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。+ v4 S# C3 q3 A; X+ y! h

9 W* \8 J5 w  P* W允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):2 [1 m/ f- n' N
% p! S/ o1 ]: {1 T
# AllowOverride controls what directives may be placed in .htaccess files.) q$ j2 v( B# E; K3 y% G
# It can be “All”, “None”, or any combination of the keywords:
/ ]* E+ q7 o- R! }, ~, S0 X# Options FileInfo AuthConfig Limit. K- V6 ~" o! t' ~3 u) V7 [
#8 k' r3 \, X! X. O* l
AllowOverride All7 y) J& x& U" ~3 p
3 K) R8 g& K: \/ n. ]
在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。1 V3 K, Z& g+ C5 H. \# n9 @& {

& {2 [/ h* d- E9 zApache Rewrite模块的简单应用:
9 m) ^) q  t4 SRewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。
- E& @/ }$ K: G; A' M2 X% Q* o0 q
1、请求跳转
& _1 Q" y) V7 ^- ^% U目的是如果请求为.jsp文件,则跳转至其它域名访问。
* @6 }5 \5 K$ Z! U例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页1 d" U( d/ z! D" V
注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。3 L" Y0 ^! [4 z$ ^& {7 v% V4 w
修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容
8 P% A3 r  I" s1 a1 e
  1. RewriteEngine on+ |+ O7 Q5 {! t; S
  2. #开启Rewrite模块
    , A  r0 j( K, n/ H, f$ Q0 j
  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为不区分大小写) c0 q& a  w; K! e2 {
2、域名跳转
( s& g* ?( f' j9 K3 R/ S" j" F如果请求为old.xp6.org下的所有URL,跳转至b.: W; E3 I; O" |: g# O
  1. RewriteEngine on3 ]5 B: B  [0 q4 w
  2. #开启Rewrite模块
    , [! s, e" S; c5 h* p5 E! q
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]
    4 k* \+ |0 H+ {/ y$ ~
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符1 _' o: U* a1 k
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
+ U" v8 K" A9 g( q2 Z. t. N如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
/ S  w% _8 Q% h, S1 ]8 E# g
  1. RewriteEngine on/ N* x2 }- E% }+ o/ ?2 `% w
  2. #开启Rewrite模块
    5 }, n6 _2 N7 g$ ]  g
  3. RewriteCond %{HTTP_REFERER} !^$/ M. D) J, ]6 t" G" {9 ]6 r4 f; R
  4. #如果不是直接输入图片地址/ C9 b0 U/ n/ S1 _. {! u
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]
    / ^! t: _; N2 A! v' o' {2 X
  6. #且如果不是img.xp6.org所有子域名调用的
    7 L# E' r$ a  X# T2 c
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]/ t# D0 H% d& b  F+ |6 m& {
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]
      U' {3 U; e" s& l: i( n1 [! k
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]
    0 _& T8 a/ _" K4 Q4 I7 F
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]
    9 s' S* f, V4 J8 L3 Z
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]; p4 ?  o2 X% K+ }. ~2 y6 `
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
    - M) F- M. X0 ~+ d8 w3 ]
  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文件  ?2 W. B, W( w9 r2 W: _0 G- V3 @
在Apache2\conf\httpd.conf 最后一行添加
* J6 w$ v6 p/ z' [" z/ B
  1. RewriteEngine On- {  H  ?& J) X
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪) j9 d4 e. q3 K  A6 c! d4 C: B

  r0 W8 C0 P7 y/ `! \' `Linux+Apache环境配置类似。& J  x6 q4 |6 j$ x1 J3 {) J& Z

. L+ j" T% [5 _2 ?+ ?5 Q
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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