搜索
查看: 8139|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2" b$ c: K5 C1 q6 n
1 G! V4 N7 {$ h+ i, p) n
加载Rewrite模块:: O5 Q$ \* J1 w8 V: C
在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。
  ?2 C0 D1 z& D: D/ H7 D# N8 y, h' q( w
允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):
* a6 ^& ^/ U: I( M% Z2 m" t' J* k. Z
. x; X0 M  t" |+ V4 L# AllowOverride controls what directives may be placed in .htaccess files.1 }. A4 Y- @% C, ^- G2 N4 O
# It can be “All”, “None”, or any combination of the keywords:
5 _: f# _- q* s  c3 s$ p+ t0 H: r# Options FileInfo AuthConfig Limit
0 C+ S$ I# `" K) E( p& Y* x5 F#: K9 A- p; }! G) ^
AllowOverride All
& N6 M: [3 t( ^- {7 I. ^* l- S. z) l* G! o# w7 q! V
在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。. [7 X( P$ W2 d. J1 @' ]2 N( \

+ m2 B  s0 K; l0 o+ L! m4 NApache Rewrite模块的简单应用:( [2 Q/ U$ \" l0 ^4 L
Rewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。
) J8 z1 n# u9 l
# d  J7 Y8 R4 t1、请求跳转) W" U  p/ P, S! d) B
目的是如果请求为.jsp文件,则跳转至其它域名访问。
: T( k' }, Q* S7 o例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页
) B8 p8 }9 e0 `+ f* ?注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。
  D" F5 o) Y5 t( `; z修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容
& c) E+ T# D) p' c
  1. RewriteEngine on
    # [5 m) ?5 J5 \5 W3 r
  2. #开启Rewrite模块
    9 z% s, ]6 n/ ^
  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为不区分大小写
. `; r2 s3 G" K- J+ f3 z2、域名跳转, m6 y) W' @) G4 u
如果请求为old.xp6.org下的所有URL,跳转至b.
$ u% c0 h4 x9 q# G0 ~; A& H
  1. RewriteEngine on
    % x$ a* \& q! Y# N
  2. #开启Rewrite模块- R7 R3 F  x3 A2 n$ x5 V
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]
    / \. F1 ]4 H1 p! A
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符
    - C% j4 K: O2 |
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
+ g* K6 i# Y* l: j如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容! u  {2 x% f" r# ?
  1. RewriteEngine on
    7 c$ B3 i2 ^  f1 l, K
  2. #开启Rewrite模块0 m* u. S: Z3 R8 \9 p5 E! c
  3. RewriteCond %{HTTP_REFERER} !^$
    : v3 H7 y# @+ q6 i
  4. #如果不是直接输入图片地址
    + `7 f7 _! m$ ?. g2 x4 G9 W( z% b
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]
    # n+ y" a# H- @6 @# X
  6. #且如果不是img.xp6.org所有子域名调用的
    1 Z/ r* G: I7 Z; u0 {
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]! @3 b/ p' p) x& @1 c
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]
    6 c+ ~! C; B. d1 Q: {9 s, {
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]2 J- l5 X( m. I/ m, r; x+ j
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]
    % P, _" n( }) r8 r' p# U
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]6 `7 F( F2 ]6 p5 U  j. i" \9 g
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
    0 [; u. b9 {5 I* p
  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文件
- m5 a1 \8 C, {4 w- p在Apache2\conf\httpd.conf 最后一行添加3 F0 _) G" w# R( i. a0 D5 u; b
  1. RewriteEngine On
    8 }/ \( y8 r8 Y% K
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪
+ j0 W" Z1 E6 |+ `/ }
9 Z/ Y! f+ K3 \9 |8 j" c: yLinux+Apache环境配置类似。
% l- ~+ T: o# m
) m4 @: ~. X( C. k* J; N
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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