搜索
查看: 12166|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2
3 N+ Y; M; r/ \, E) H9 d9 A
: y% B* n. j$ ]加载Rewrite模块:" [% R% o1 |3 g
在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。
. ]5 L6 S& i$ n5 n0 J+ P$ C  E. U5 M4 d
允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):/ [$ A0 i( A5 O4 R, Q* r% N9 m5 c
  T6 v) Q; C& q  O
# AllowOverride controls what directives may be placed in .htaccess files.# ]7 [. X6 j; q4 b; E7 N; k
# It can be “All”, “None”, or any combination of the keywords:
; R/ W# i# n; z# K5 I/ h3 v1 O# Options FileInfo AuthConfig Limit/ x7 x0 |5 C* Y& X
#, e7 K$ ^& ~; O9 E
AllowOverride All
& A3 ^$ ^0 l3 ?$ X: k; o4 i; e5 s5 [% F" {/ {- M1 p" x
在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。$ t- y+ Y1 J$ A7 ?  Q

& J: u  n7 i7 B" s$ B' @* sApache Rewrite模块的简单应用:3 J( g0 T- v# R, w3 ^
Rewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。
7 N$ i7 ^% u) o0 u& J4 V% t
" A- \& U9 V! k9 M* G% k+ {: v" x1、请求跳转
5 v! H' S. x3 U' a目的是如果请求为.jsp文件,则跳转至其它域名访问。6 s+ @( W) O3 X
例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页* v% v- a) t0 g' X& O
注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。4 i0 y$ }8 w' u' X# ~/ t
修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容9 Z1 o+ ^$ m2 e- d: i: O( l
  1. RewriteEngine on5 S  E$ ]% e5 |0 m
  2. #开启Rewrite模块
    # v- l' H$ d8 S" x
  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为不区分大小写$ i7 P5 q; t4 S/ v. S3 r
2、域名跳转3 S, o- L6 |# P  c, |3 \  h
如果请求为old.xp6.org下的所有URL,跳转至b.
4 z' Z+ V6 y; }" l% T7 `
  1. RewriteEngine on' C  U1 M6 p  L
  2. #开启Rewrite模块9 s& U4 }' a; U) F
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]
    ( f2 G6 g( {& }8 L
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符' _" Y0 d- D9 @# Q- w1 p
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
% @1 Q4 c: a" |$ Y8 J如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
! {* Y2 ~/ \2 T5 G% u3 _
  1. RewriteEngine on
    $ ?, w$ D- b) B5 N+ ]6 p4 P
  2. #开启Rewrite模块
    ; y; N5 u" ^' S/ [7 \
  3. RewriteCond %{HTTP_REFERER} !^$
    9 g0 \- T$ d7 F: d7 G" a
  4. #如果不是直接输入图片地址
      q3 C: ?5 n0 r2 o# T& b
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]
    , a' j7 p' |- R2 \6 q: }) s2 f. |
  6. #且如果不是img.xp6.org所有子域名调用的
    * d  B7 Q$ e+ K
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]
    $ T7 ^$ J5 T& E
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]2 [( e2 j- r1 f* S7 F
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]( F+ E; e$ L  S9 ]$ S
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]: F1 ?6 L( `  `; O* \5 m+ X2 R
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]
    9 i( B) G8 W! y
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]9 K7 A. `2 o) {
  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文件! {4 T( _/ }: [+ {3 i+ f
在Apache2\conf\httpd.conf 最后一行添加+ ?: i. K5 W# g5 R) n0 D; K
  1. RewriteEngine On
    $ p3 C; A$ M0 j
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪3 f9 A( f+ J) ]1 ]9 W& s
" \$ ]) T' i2 I: |5 ^
Linux+Apache环境配置类似。
4 X. ]: n& M) a* r5 j' u  U- c1 @9 d! t- `  D4 }
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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