搜索
查看: 11830|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2. M" f2 A2 P& x) s2 I; v

" w2 n8 a% j' Z% q加载Rewrite模块:
, s: q/ f( \( j在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。
5 x* w0 j: C7 n' ?  c/ _* O% S5 I- |  A  i
允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):
' @6 x( U5 ?2 q! ^3 ^0 c' `" ~8 ^( t8 W: e% g" r
# AllowOverride controls what directives may be placed in .htaccess files.' [7 N; [% f/ i& Q& [
# It can be “All”, “None”, or any combination of the keywords:
0 J- n5 |( B1 q5 E# Options FileInfo AuthConfig Limit
# E* d+ n& x) S7 a#% n$ k8 W' M. Q
AllowOverride All
0 u( i: \$ j3 x( ?
) ?' E- ?3 T0 M6 q在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。: {8 m% S1 T! k! a+ M# S; j

+ S/ I5 w: z* s1 m- D) uApache Rewrite模块的简单应用:
  [1 ^( N# Q1 z8 k. m+ sRewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。. M1 X; c4 D( t* t6 S) m
9 i+ y8 }+ ]1 c: E# [! H( T
1、请求跳转' D% ]( b2 a$ p( d$ u! F1 I
目的是如果请求为.jsp文件,则跳转至其它域名访问。
: u& E: F& C: E例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页
: S% L: l% a" z. O* ~+ l注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。
: t: O6 e  u9 A3 O8 C! B修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容
; Y1 _* ]! z& w1 h! T! w; M. }
  1. RewriteEngine on1 v! {5 s. ]( `6 L, P  k
  2. #开启Rewrite模块
    ( k' {3 L6 _  K6 a% |9 O- ^8 V- s
  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为不区分大小写$ H! l7 i8 N  z- C
2、域名跳转1 T1 E! t4 C% O* K
如果请求为old.xp6.org下的所有URL,跳转至b.. ?9 D/ Y4 X* y4 q
  1. RewriteEngine on
    " J4 q8 k/ \( Z1 i1 ^  ?
  2. #开启Rewrite模块( f. A- A; f; t& J- }
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]
    9 D; s9 L3 p2 C/ S" D& x* c
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符' ^+ V7 ?' X# f5 o/ ?* R
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
! I; \9 m' C- E! z& E! F如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
; l8 R" S1 v8 F! e- x$ A) x
  1. RewriteEngine on
    2 W2 f* _, }, c
  2. #开启Rewrite模块  Y6 u) l6 ~. I3 k7 R+ E# }
  3. RewriteCond %{HTTP_REFERER} !^$
    9 D" r( x: J, y  `- _" e
  4. #如果不是直接输入图片地址
    . [( p& E% }+ A( p: r; J; m
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]
    6 u5 z+ O# f7 V$ c+ Z+ h; S
  6. #且如果不是img.xp6.org所有子域名调用的
    & d0 Q1 L) l! E8 ~0 q1 k/ q( o
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]) M1 t' h- e4 S" Q( q1 t  s3 T% g
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]
    ! {& W  ~3 @/ h( F$ @+ u' z
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]* V7 y8 X+ L$ ?
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]& w" |& a" p& L+ ]5 l* Y
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]
    1 L# U$ g- z/ c" x
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
    4 }) V# Z, D4 b/ @# R- [
  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文件
) w4 w* a5 `. l; f) d4 U在Apache2\conf\httpd.conf 最后一行添加3 J! q" L) k; c' k
  1. RewriteEngine On) w7 d; E' k0 O! _' W  U
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪" U1 r' a- d7 G/ n( N4 K

0 g( ]" `6 C# o5 j7 n2 U6 SLinux+Apache环境配置类似。; X1 W7 p/ I$ w* K; b9 _$ B! C
$ Q1 v& g/ z: m2 S& Y' k0 ?- {
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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