搜索
查看: 11569|回复: 1

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

[复制链接]
发表于 2019-5-13 09:29:10 | 显示全部楼层 |阅读模式
环境:系统 Windows+Apache 2.2
: e* M. b- j* c: \9 e8 ]5 }, m/ @9 ~2 ~1 v. u- K
加载Rewrite模块:
9 D0 u, s1 J0 R( O' j% H" n' P在conf目录下httpd.conf中找到 LoadModule rewrite_module modules/mod_rewrite.so 这句,去掉前边的注释符号“#”,或添加这句。
: y2 F( q- n( g1 J6 Z# h5 a! g
+ @+ o+ v$ u4 S8 r, s允许在任何目录中使用“.htaccess”文件,将“AllowOverride”改成“All”(默认为“None”):
( b/ x+ p0 N4 q& y
" q: U4 y# g0 x# AllowOverride controls what directives may be placed in .htaccess files.
% |, ~; T; K- Q9 Y# It can be “All”, “None”, or any combination of the keywords:
1 H* x' W# r) f6 @. r# Options FileInfo AuthConfig Limit6 K0 G# t" L$ t. C% K/ V8 e
#
$ _+ b" t2 L* M. s" Z0 Q2 [AllowOverride All% D: |& @2 B$ r: V+ V* f4 X9 d- c
1 G0 X3 l" l2 s) ?
在Windows系统下不能直接创建“.htaccess”文件,可以在命令行下使用“echo a> .htaccess”建立,然后使用记事本编辑。或者,系统设置显示扩展文件名,打开记事本另存为.htaccess文件,文件类型,所有文件。
4 l! i, R& P7 }1 C9 w5 L! r$ q3 q9 c+ @% L: `" _
Apache Rewrite模块的简单应用:
! v9 w1 F' P4 l0 c8 q  a. {" D2 WRewrite的所有判断规则均基于Perl风格的正则表达式,通过以下基础示例能写出符合自己跳转需求的代码。  ?- L0 R6 l- S8 c1 Z; _
9 U! |, n. }/ V! m6 ^9 c
1、请求跳转
$ n) {2 B- c1 ]* e7 l+ @" _目的是如果请求为.jsp文件,则跳转至其它域名访问。7 f4 n+ x6 J8 P' i* V- |, i+ N
例如:访问www.xp6.org/a.php跳转至b.xp6.org/b.php网页,访问www.xp6.org/news/index.php跳转至b.xp6.org/news/index.php网页
! k" U: z; ?# E9 W4 q( g0 M注意:不是使用HTML技术中的meta或者javascript方式,因为www.xp6.org/a.php这个文件并不存在,用的是Apache2.2服务器中的Rewrite模块。
" S3 E3 Z: e' U修改 .htaccess或apche的配置文件httpd.conf文件,添加以下内容
* B) {2 ?- {( o$ P% a1 G
  1. RewriteEngine on- p- B+ o* k$ h. b6 {+ h
  2. #开启Rewrite模块
    % w0 V# H" p$ k, k5 t( ^: l6 t3 M. r  `
  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为不区分大小写! w( @: g6 q, X  m; q
2、域名跳转, T5 V% x$ c# l
如果请求为old.xp6.org下的所有URL,跳转至b.$ x" p, p& ~9 k0 r/ i
  1. RewriteEngine on+ K; x' @2 M8 D- ~' g! e
  2. #开启Rewrite模块. b8 R3 Z; \5 @  _2 E4 Y* a9 I
  3. RewriteCond %{REMOTE_HOST} ^old.xp6.org$ [NC]
    6 s( D; Q* l0 W+ m0 w  P
  4. #针对host为old.xp6.org的主机做处理,^为开始字符,$为结尾字符5 V4 p, `9 P" w4 a: ?
  5. RewriteRule (.*) http://b.xp6.org/$1 [R=301,L,NC]
复制代码
3、防盗链
: W( W1 M7 d- H' q如果本网站的图片不想让其它网站调用,可以在 .htaccess或者apche的配置文件httpd.conf文件中添加以下内容
' H' Q: i$ _8 n1 D) \
  1. RewriteEngine on
    6 ]3 H* l+ O3 F; _
  2. #开启Rewrite模块( R4 B2 @" T2 Z1 y' w- \# e
  3. RewriteCond %{HTTP_REFERER} !^$. k0 D' Z) _. F& m
  4. #如果不是直接输入图片地址
    ) k2 Z+ \) i! n# L
  5. RewriteCond %{HTTP_REFERER} !img.xp6.org$ [NC]
    ; K, d% ^& }/ b$ \7 g  W  w
  6. #且如果不是img.xp6.org所有子域名调用的
    3 g7 d( P! q" [
  7. RewriteCond %{HTTP_REFERER} !img.xp6.org/(.*)$ [NC]0 w9 H& G4 J. Y4 b: n2 [# ^
  8. RewriteCond %{HTTP_REFERER} !qq.com [NC]. w/ ]% H: o: B9 i9 {  b8 c! G% C
  9. RewriteCond %{HTTP_REFERER} !google.com [NC]
    ; [/ P* p# |- }; h0 p2 F
  10. RewriteCond %{HTTP_REFERER} !google.cn [NC]
    / k, u: ]% U5 g" d5 \( z# M9 B
  11. RewriteCond %{HTTP_REFERER} !baidu.com [NC]! z  S+ Y9 G# V. z& b( I
  12. RewriteCond %{HTTP_REFERER} !feedsky.com [NC]
    2 x3 n5 V/ V/ G6 c2 d: 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文件
4 O5 `1 C& K# F: Z在Apache2\conf\httpd.conf 最后一行添加9 G% L! j$ \" R1 c0 w0 b  P: M
  1. RewriteEngine On
    & a2 T( {4 S- z7 L1 m! }7 ^( b
  2. RewriteRule ^(.*)-htm-(.*)$ $1.php?$2
复制代码
重启Apache,登陆后台开启全伪
8 I' O& Q+ i! h2 ^( G' r' c8 ?- T/ G& ~
Linux+Apache环境配置类似。3 f4 r, h' C" t% q" Z
7 a2 @5 `* F% ~7 F
回复

使用道具 举报

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

本版积分规则

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

虾皮社区,成立十年了!

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

Copyright © 2007-2019 xp6.org Powered by Discuz

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