搜索
查看: 11849|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2
4 K  m, o) T6 u- h0 e. p/ P/ d5 P
加载Rewrite模块:- y. T+ b  r* o& J% i! |! M3 F$ H, W, o& r
在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。8 Q. n9 Q! e5 Z! Z
# ^4 Z2 A- D9 i
允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):5 _0 j2 c  n8 i7 A& Y7 M9 t( a. U

' Z% c' M+ x, ^" W$ W6 @# AllowOverride controls what directives may be placed in .htaccess files.# D$ A7 }' c& H) a$ ^
# It can be “All”, “None”, or any combination of the keywords:' z6 k1 P! e1 c0 P
# Options FileInfo AuthConfig Limit( a3 n: x8 @5 j7 M7 A0 w
#2 N& l$ H- L1 J6 K/ m
AllowOverride All
: P" q2 x; B& G; @+ C( o% e4 Y' r( H3 m; `1 t
在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。
4 i: l- }- ~/ F; o5 p& _4 |7 H# Z: E: d, {- _6 l3 F; b
Apache Rewrite模块的简单应用:
' t" p2 I; B# t$ C" w! O8 p* \" D: pRewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。' `! @0 n& x# b' [
9 V6 g9 c( \' ]8 G5 ~/ b
1、请求跳转# a! f6 [6 C$ \$ V' R
目的是如果请求为.jsp文件,则跳转至其它域名访问。  X9 ]2 M+ ?. \$ K
例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页
, C( n9 S6 ]% ^7 @6 j  D" c" `注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。
, n7 m1 E, J* F0 y修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容
7 `/ l5 {/ M" m. }8 F  s/ u; u: f9 D
  1. RewriteEngine on% r; z% ~0 o6 ?1 T7 y/ V
  2. #开启Rewrite模块$ Z1 G% ?" O1 q
  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为不区分大小写/ R# p# f9 j+ W& k& N- x) A5 v5 r
2、域名跳转9 I3 p9 b& J+ o
如果请求为old.xp6.org下的所有URL,跳转至b.. A5 c" R/ N/ Z9 L% I% v- j
  1. RewriteEngine on
    . v+ M2 b, d# B# R
  2. #开启Rewrite模块0 B, f+ r3 G8 P$ y" S/ J) [
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]1 D2 {+ I) r& y) h
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符
    # S% m6 R. \* y6 H& a( `1 `
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链; Q! _5 Z/ a# G4 f. F$ N: e
如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
4 @8 a' c2 K% P
  1. RewriteEngine on
    , f7 q, i4 a3 s
  2. #开启Rewrite模块
    , U* ^, m2 b2 h4 P5 h0 H# d
  3. RewriteCond %{HTTP_REFERER} !^$
    4 t1 U1 s1 e9 D3 p+ e) R
  4. #如果不是直接输入图片地址1 R" q3 G8 j8 c  O; s/ {
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]
    # ~4 B. f( I+ F: K
  6. #且如果不是img.xp6.org所有子域名调用的: N4 O3 I( l( k; S4 `
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]
    $ n2 V5 w! T# N. `: P; g
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]8 L9 P, k. i  l0 y* K- H+ c
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]/ H' I: K! t1 @, Q, G$ Z4 d" g
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]1 o: e$ R) S- U0 F+ U! f' a
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]' d3 z; h+ L+ I/ E: ~
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
    - f0 R9 B" {& O5 d) a5 ]  F
  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文件
! X1 \" c, v" {8 r9 C在Apache2\conf\httpd.conf 最后一行添加
& a" \0 i0 B- @3 M
  1. RewriteEngine On1 k8 D, n: `5 }% Q
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪0 m' r  W& ^3 c8 t  l, M
7 T4 D& e( c% O7 H
Linux+Apache环境配置类似。
5 j, D; c7 r' t6 e7 R9 Q
" C! C: V/ l# h" K: D5 a
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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