搜索
查看: 11660|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.23 T  Z1 D8 y+ H9 N
; A0 y$ @7 T8 G: e' i
加载Rewrite模块:
( p  ~3 t, G: e8 g在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。
+ X% d  v$ B* ?5 _/ R
8 K$ o) Y! p$ I( a8 j- B0 ^允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):
/ @% ?2 x+ q- a/ j6 m0 {$ k% b! r0 v. W: @9 [
# AllowOverride controls what directives may be placed in .htaccess files.
! p6 l' t7 C7 z( B+ U! h0 W# It can be “All”, “None”, or any combination of the keywords:9 \8 y& D# O* h7 H4 r/ W
# Options FileInfo AuthConfig Limit6 y: Z! E. S5 [
#
3 j0 G) {. q+ \7 \* U$ P2 S+ r9 oAllowOverride All  p& }7 E  s4 _$ M( V  N! k# C8 w

- S/ T8 l+ i  d在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。4 V8 S6 V0 w, J6 h1 P" U( Z5 W

4 _, O$ N/ s3 d" `/ MApache Rewrite模块的简单应用:2 u+ J. F0 w6 N8 s9 Q
Rewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。1 U6 J1 B' B" K7 ]6 w3 K5 d
; \9 l! X! @6 M- X0 v. T5 }
1、请求跳转, ^* {  R# ]6 s# j( U2 V
目的是如果请求为.jsp文件,则跳转至其它域名访问。$ K# _+ {8 i: o0 c1 {; C
例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页8 A6 H* s" n8 J  }8 Z; B
注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。
: s4 Q- N% B( Z/ }修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容
$ _' N* I2 `2 T  R7 U- C3 D' b
  1. RewriteEngine on
    0 P8 B1 S. f+ l% t: U/ N7 b
  2. #开启Rewrite模块4 k" E) Z! s: O5 |5 L! T
  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为不区分大小写$ b, Z3 u% B# ?- l9 j( E9 T
2、域名跳转- {, M( P+ U7 K% S5 h
如果请求为old.xp6.org下的所有URL,跳转至b.
- A+ L3 F9 h9 G6 w; I- W7 Y1 A
  1. RewriteEngine on
    6 `3 i' [$ y2 Q0 _& Z+ |/ e8 z# P
  2. #开启Rewrite模块) k6 F( i* }3 P3 o) l
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]
    + A# l/ _! \  x# E
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符
    3 j1 G2 R9 n# w3 i
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
$ k: v& o7 z' I% v! e如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
  m2 k7 a) N' M* ^$ ]- c
  1. RewriteEngine on
    1 C. y6 Y& W* D7 X9 J
  2. #开启Rewrite模块% q( U; W* a/ Z! M" x) }
  3. RewriteCond %{HTTP_REFERER} !^$
    - P! t+ Y, M$ m3 ~2 U4 q' X
  4. #如果不是直接输入图片地址; _- B0 T/ W2 b# i0 ^8 A0 [
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]2 j4 a7 h" G0 c2 F# {& q" K5 C' E
  6. #且如果不是img.xp6.org所有子域名调用的  |% M/ b8 X) @! u9 E! \1 B4 N
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]
    7 y% I) F/ c& Z3 o
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]
    4 g# z: G+ l% g  V
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]1 s+ `" ~: J. K/ x' X5 ^
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]: i' B6 C* Y6 K) ]& b1 s2 G
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]( T5 Q1 @: }( G
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
    4 A+ Z* v$ \- r2 i4 Q4 L: d- W8 y
  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文件
1 l, }3 I6 F- {6 s$ S7 {在Apache2\conf\httpd.conf 最后一行添加! ]1 n3 `7 \: x  O7 y8 l
  1. RewriteEngine On9 e+ S/ t2 b+ z/ Y8 M+ o0 w
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪* L" R- D0 q7 o- V% I( }3 m
0 L. Y4 H8 P# |' v% H
Linux+Apache环境配置类似。1 S% f4 I+ j1 z$ ^
9 W/ W0 B: `* \# \* X+ O
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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