搜索
查看: 11956|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2
5 }5 ]% R. k* }& V  A
* q# x1 L' Y5 v7 u# y* r加载Rewrite模块:  Z( U5 ?! y- s, X; \
在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。* y8 Q8 @& r2 F5 A! \

; U! @6 P* M9 [4 t允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):
5 E( e( M$ n6 h6 y# a6 i4 t6 f: N2 H9 H
# AllowOverride controls what directives may be placed in .htaccess files.; _2 d. g& Z$ y2 Y0 M% I" i
# It can be “All”, “None”, or any combination of the keywords:
  i2 i+ f4 ~: u' D6 C# f5 v9 P# Options FileInfo AuthConfig Limit
. s0 R  k4 s) y# P#5 ~" R" R7 C* |- n# l& _0 X; Y
AllowOverride All' ^, m5 k" f& G- T3 E/ V

& V7 ?% r9 `6 x2 u8 {5 g在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。
/ t  o0 i0 b- s6 X& F5 l4 l$ S# m% L, V) N  V- x/ i+ i) U- q
Apache Rewrite模块的简单应用:/ `/ ~- ]4 d1 I- Z: L
Rewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。1 {( ?! \+ q5 o) D, r- m  g
& e$ ]' ]- u$ J& u3 W
1、请求跳转$ `  ~) [+ k! v6 O4 X$ I
目的是如果请求为.jsp文件,则跳转至其它域名访问。
+ N1 ?7 n( z( c! h例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页2 i7 p/ ]  V8 s7 C
注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。
: l, P+ v7 C; M4 _9 X0 ^3 S修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容: u  k! O+ m! M# S( j0 `
  1. RewriteEngine on
    4 {# A$ h& Y# o8 i9 \0 O  Z/ t
  2. #开启Rewrite模块( a% O  G: [  O7 ?  H
  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为不区分大小写
( e) f9 S$ E( s1 t7 R! S. v2、域名跳转
' |/ R1 M' u9 m. K+ f- g, r2 ?7 p7 ]如果请求为old.xp6.org下的所有URL,跳转至b.
( v, B( x+ r9 q
  1. RewriteEngine on
    0 k& g6 y( K- v0 ?# I
  2. #开启Rewrite模块
    % a5 U! o& Z" E+ T0 `
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]% Z- }  u3 b- t( v+ b
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符
    / U' \5 m5 [/ O; J) e4 b
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链7 Z/ c* ~: M1 A9 I5 @/ g
如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
- Y/ Q1 H! C! ~9 V$ n+ b: u! O
  1. RewriteEngine on. s1 V" C" z) [( z; D* }
  2. #开启Rewrite模块2 ?) }  `' h6 u" Y+ e! Q
  3. RewriteCond %{HTTP_REFERER} !^$
    " @/ m. T4 C( e( u" M" K
  4. #如果不是直接输入图片地址9 b! t6 g& Z* C* t
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]
    3 m9 j  w* U( b, t5 g" F
  6. #且如果不是img.xp6.org所有子域名调用的
    7 R3 S( m3 _8 l1 N7 p
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]' q: S9 ^# x1 V, n9 u
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]
    4 m. D$ K2 W, b: ~+ R* B4 o0 A2 P/ b
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]1 p: f4 h. c5 a% j3 N, f
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]
    4 `, `+ a5 u  i( O' S/ h
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]( e1 G% t( [. ^- [# @" y- `9 t. |8 U# ^
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
    # F7 N; u- h2 M& \" Q2 ^
  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文件
0 t' J! Q: }( O# F在Apache2\conf\httpd.conf 最后一行添加6 ^+ J$ e) C% ?3 J* z
  1. RewriteEngine On
    1 X: {4 x; W& E/ y3 C4 B3 t& M  G0 ~
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪9 ]4 ]$ j3 }) ?. r: L
. G" G: A" f: U7 F0 \
Linux+Apache环境配置类似。$ e7 j% ]) o: x. G/ F& X7 R
9 f% i7 J. g! }7 o
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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