收藏 分享(赏)

Apache URL重写.docx

上传人:hwpkd79526 文档编号:7224877 上传时间:2019-05-10 格式:DOCX 页数:28 大小:89.39KB
下载 相关 举报
Apache URL重写.docx_第1页
第1页 / 共28页
Apache URL重写.docx_第2页
第2页 / 共28页
Apache URL重写.docx_第3页
第3页 / 共28页
Apache URL重写.docx_第4页
第4页 / 共28页
Apache URL重写.docx_第5页
第5页 / 共28页
点击查看更多>>
资源描述

1、URL 重写简介本篇文档是 mod_rewrite 参考文档 的补充,阐述了使用 mod_rewrite 之前必须了解的基本概念。其它文档则作了更加深入的探讨。不过这篇文档对于初学者是一篇很好的入门读物。简介Apache 的 mod_rewrite 是提供了强大 URL 操作的杀手级模块,可以实现几乎所有你梦想的 URL 操作,其代价是你必须接受其复杂性,因为 mod_rewrite 对于初学者的主要障碍就是不容易理解和运用,即使是 Apache专家有时也会发掘出 mod_rewrite 的新用途。换句话说:你或者是打退堂鼓永不再用,或者是喜欢它并一生受用。目前存在这样一种倾向:许多初学者只是

2、把 URL 重写规则当着是会变戏法的魔咒,而并未在使用中真正理解这些规则的含义。本篇文档试图给出充分的背景知识,以便于初学者随后的理解,而不是盲目的复制和粘贴。正则表达式mod_rewrite 使用的是 Perl 兼容的正则表达式语法。本文不打算详细讲解正则表达式语法,你可以到 PCRE man page, Perl regular expression man page, Mastering Regular Expressions, by Jeffrey Friedl 获得这些内容。RewriteRule 指令的说明部分有一个简单的正则表达式语法简介,可以去参考一下。另外需要说明的是可以在表

3、达式的最前面加上一个感叹号(!)表示不匹配,不过这种用法并不符合正则表达式语法。正则表达式的反向引用能力这是很重要的一点:一旦在 Pattern 或者 CondPattern 中使用了圆括号,就会建立内部的反向引用,可以使用$N 和%N 来调用(见下述),并且在 Substitution 和 TestString 中都有效。图-2 说明了反向引用被转换和展开的位置。图 -2: The back-reference flow through a rule. RewriteRule basics(此部分文档尚未完成) Basic anatomy of a RewriteRule, with exh

4、austively annotated simple examples. Rewrite Flags(此部分文档尚未完成) Discussion of the flags to RewriteRule, and when and why one might use them.Rewrite conditions(此部分文档尚未完成) Discussion of RewriteCond, looping, and other related concepts. Rewrite maps(此部分文档尚未完成) Discussion of RewriteMap, including simple,

5、but heavily annotated, examples.htaccess files(此部分文档尚未完成) Discussion of the differences between rewrite rules in httpd.conf and in .htaccess files.环境变量此模块会跟踪两个额外的(非标准)CGI/SSI 环境变量:SCRIPT_URL 和 SCRIPT_URI。他们包含了当前资源的逻辑 网络视图,而标准 CGI/SSI 变量 SCRIPT_NAME 和 SCRIPT_FILENAME 包含的是 物理 系统视图。注意:这些变量保持的是 其最初被请求时的

6、 URI/URL,即在任何重写操作 之前 的 URI/URL。其重要性在于他们是重写操作重写 URL 到物理路径名的原始依据。示例SCRIPT_NAME=/sw/lib/w3s/tree/global/u/rse/.www/index.htmlSCRIPT_FILENAME=/u/rse/.www/index.htmlSCRIPT_URL=/u/rse/SCRIPT_URI=http:/ 重写技术细节本文探讨一些 mod_rewrite 和 URL 匹配的技术细节。内部处理此模块的内部处理极为复杂,但是为了使一般用户避免犯低级错误,也让管理员能充分利用其功能,在此仍然做一下说明。API 阶段首

7、先,你必须了解 Apache 是分若干阶段来处理 HTTP 请求的。Apache API 对每个阶段都提供了一个 hook 程序。mod_rewrite 使用两个 hook 程序:其一,从 URL 到文件名的转换 hook(用在读取 HTTP 请求之后、授权开始之前); 其二,修正 hook(用在授权阶段和读取目录级配置(.htaccess)之后、内容处理器激活之前) 。所以,Apache 收到一个请求并且确定了响应主机( 或虚拟主机)之后,重写引擎即开始处理服务器级配置中的所有 mod_rewrite 指令(此时处于从 URL 到文件名转换的阶段),此阶段完成后,最终的数据目录便确定了。接下

8、来进入修正程序段并触发目录级配置中的 mod_rewrite 指令。这两个阶段并不是泾渭分明的,但都实施了把 URL 重写成新的 URL 或者文件名。虽然 API 最初不是为此目的而设计的,但是现在它已经成为了 API 的一种用途。记住以下两点,会有助于更好地理解:1. 虽然 mod_rewrite 可以将 URL 重写为新的 URL 或文件名,甚至将文件名重写为新的文件名,但是之前的 API 只提供从 URL 到文件名的 hook。在 Apache 2.0 中,增加了两个丢失的 hook 以使得处理过程更加清晰。不过这样做并没有给用户带来麻烦,用户只需记住这样一个事实:借助从 URL 到文件

9、名的 hook 比最初 API 设计的目标功能更强大。 2. 令人难以置信的是,mod_rewrite 还提供了目录级的 URL 操作(.htaccess 文件),而这些文件必须在将 URL 转换成文件名之后才会被处理( 这是必须的,因为 .htaccess 存在于文件系统中)。换句话说,根据 API 阶段,这时再处理任何 URL 操作已经太晚了。为了解决这个“鸡和蛋“的问题,mod_rewrite 使用了一个小技巧:在进行一个目录级的 URL/文件名操作时,先把文件名重写回相应的 URL(通常这个操作是不可行的,但是参考下面的RewriteBase 指令就能明白它是怎么实现的了 ),然后,对

10、这个新的 URL 建立一个新的内部的子请求,再重新开始 API 阶段的执行。 另外,mod_rewrite 尽力使这些复杂的操作对用户透明。但仍须记住:服务器级的 URL 操作速度快而且效率高,而目录级的操作由于这个“鸡和蛋“的问题速度较慢而且效率也低。但从另一个侧面看,这却是 mod_rewrite 得以为一般用户提供( 局部限制的)URL 操作的唯一方法。牢记这两点!规则集的处理当 mod_rewrite 在这两个 API 阶段中开始执行时,它会读取配置结构中配置好的 (或者是在服务启动时建立的服务器级的,或者是在遍历目录采集到的目录级的)规则集,然后,启动 URL 重写引擎来处理(带有一

11、个或多个条件的)规则集。无论是服务器级的还是目录级的规则集,都是由同一个 URL 重写引擎处理,只是最终结果处理不同而已。规则集中规则的顺序是很重要的,因为重写引擎是按一种特殊的顺序处理的:逐个遍历每个规则(RewriteRule 指令),如果出现一个匹配条件的规则,则可能回头遍历已有的规则条件(RewriteCond 指令)。由于历史的原因,条件规则是前置的,所以控制流程略显冗长,细节见图-1。初级 URL 重写指南本文是 mod_rewrite 参考文档的补充材料。阐述在实际应用中如何解决网管所面临的基于 URL 的典型问题,并详细描述了如何配置 URL 重写规则集以解决这些问题。注意:根

12、据你的服务器配置,有可能必须对这里的例子作些小修改,比如,在额外启用 mod_alias 和mod_userdir 的情况下要增加PT标志,或者为了适应目录级( .htaccess)的配置而将针对服务器级的规则集进行重写。对一个特定的规则集应该先透彻理解然后再考虑应用,这样才能避免出现问题。规范化 URL描述: 在有些 web 服务器上,一个资源会拥有多个 URL。在实际应用和发布中应该使用的是规范的 URL,其他的则是简写或者只在内部使用。无论用户在请求中使用什么形式的 URL,最终看见的都应该是规范的 URL。 解决方案: 对所有不规范的 URL 执行一个外部 HTTP 重定向,以改变它在

13、浏览器地址栏中的显示及其后继请求。下例中的规则集用规范的/u/user 替换/user ,并修正了/u/user 所遗漏的后缀斜杠。 RewriteRule /(/+)/?(.*) /u/$1/$2 RRewriteRule /u/(/+)$ /$1/$2/ R规范化主机名描述: 这个规则的目的是强制使用特定的主机名以代替其他名字。比如,你想强制使用 代替 ,就可以在以下方案的基础上进行修改: 解决方案: 对运行在非 80 端口的站点RewriteCond %HTTP_HOST !fully.qualified.domain.name NCRewriteCond %HTTP_HOST !$Re

14、writeCond %SERVER_PORT !80$RewriteRule /(.*) http:/fully.qualified.domain.name:%SERVER_PORT/$1 L,R对运行在 80 端口的站点RewriteCond %HTTP_HOST !fully.qualified.domain.name NCRewriteCond %HTTP_HOST !$RewriteRule /(.*) http:/fully.qualified.domain.name/$1 L,R移动过的 DocumentRoot描述: 通常,web 服务器的 DocumentRoot 直接对应于

15、URL“/“,但是它常常不是处于最高的一级。比如,你希望访问者在进入网站时首先进入/about/目录。可以使用下面给出的规则集。 解决方案: 只需将“/“重定向到 “/about/“即可: RewriteEngine onRewriteRule /$ /about/ R也可以使用 RedirectMatch 指令解决问题:RedirectMatch /$ http:/ 结尾斜杠问题描述: 每个网管对引用目录的结尾斜杠问题都有一本苦经,如果遗漏了,服务器会产生一个错误,因为如果请求是“/quux/foo“而不是“/quux/foo/“,服务器就会去找一个叫 foo 的文件,而它是一个目录,所以就

16、报错了。通常,可以使用这个 FAQ entry 里面提到的方法解决问题。但是有时候需要使用重写规则来解决问题,比如,在应用了许多复杂的重写规则之后。 解决方案: 解决这个微妙问题的方案是让服务器自动添加后缀斜杠。为了达到目的,必须使用一个外部重定向,以使浏览器能够正确地处理后继的请求(比如对图片的请求) 。如果仅仅执行一个内部重写,可能仅仅对目录页面有效,而对含有相对 URL 的图片的页面无效,因为浏览器有请求内嵌目标的可能。比如,如果不用外部重定向,对/quux/foo/index.html 页面中的 image.gif 的请求将变成对/quux/image.gif 的请求!所以,应该这样写

17、: RewriteEngine onRewriteBase /quux/RewriteRule foo$ foo/ R又懒又疯狂的做法是把这些写入其宿主目录中的顶级.htaccess 中:RewriteEngine onRewriteBase /quux/RewriteCond %REQUEST_FILENAME -dRewriteRule (.+/)$ $1/ R但是这样一来会增加处理上的开销。将用户主目录移动到不同 web 服务器描述: 通常,许多网管在建立一个新的 web 服务器时,都会有这样的要求:重定向一个 web 服务器上的所有用户主目录到另一个 web 服务器。 解决方案: 很简

18、单,在老的 web 服务器上重定向所有的“/user/anypath“到“http:/newserver/user/anypath“: RewriteEngine onRewriteRule /(.+) http:/newserver/$1 R,L在多个目录中搜索页面描述: 有时会有必要使 web 服务器在多个目录中搜索页面,对此,MultiViews 或者其他技术无能为力。 解决方案: 编制一个明确的规则集以搜索目录中的文件: RewriteEngine on# 首先尝试在 dir1 中寻找,找到即停RewriteCond /your/docroot/dir1/%REQUEST_FILENA

19、ME -fRewriteRule (.+) /your/docroot/dir1/$1 L# 然后尝试在 dir2 中寻找,找到即停RewriteCond /your/docroot/dir2/%REQUEST_FILENAME -fRewriteRule (.+) /your/docroot/dir2/$1 L# 再找不到就继续寻找其他的 Alias 或 ScriptAlias 目录RewriteRule (.+) - PT按照 URL 的片段设置环境变量描述: 希望保持请求之间的状态信息,又不希望使用 CGI 来包装所有页面,只是通过分离 URL 中的有用信息来做到。 解决方案: 可以用一

20、个规则集来分离出状态信息,并设置环境变量以备此后用于 XSSI 或 CGI。这样,一个“/foo/S=java/bar/“ 的 URL 会被解析为“/foo/bar/“,而环境变量 STATUS 则被设置为“java“。 RewriteEngine onRewriteRule (.*)/S=(/+)/(.*) $1/$3 E=STATUS:$2虚拟用户主机描述: 如果需要为用户 username 支持一个 的主页,但不在此机器上建虚拟主机,而是仅用在此机器上增加一个 DNS A 记录的方法实现。 解决方案: 仅能对包含“Host: “头的 HTTP/1.1 请求实现。可以使用以下规则集内部地

21、将http:/ 重写为/home/username/anypath RewriteEngine onRewriteCond %HTTP_HOST www.+$RewriteRule (.+) %HTTP_HOST$1 CRewriteRule www.(.+)(.*) /home/$1$2为外来访问者重定向用户主目录描述: 对不是来自本地域 的外来访问者的请求,重定向其用户主目录 URL 到另一个 web 服务器 ,有时这种做法也会用在虚拟主机的配置段中。 解决方案: 只须一个重写条件: RewriteEngine onRewriteCond %REMOTE_HOST !.+$Rewrite

22、Rule (/.+) http:/ R,L重定向锚描述: 默认情况下,重定向到一个 HTML 锚是不可行的,因为#会被转义为 %23。This, in turn, breaks the redirection. 解决方案: 在 RewriteRule 指令中使用NE标志( 不转义)。 依赖于时间的重写描述: 在页面内容需要按时间的不同而变化的场合,比如重定向特定页面等,许多网管仍然采用CGI 脚本的方法,如何用 mod_rewrite 来实现呢? 解决方案: 有许多名为 TIME_xxx 的变量可以用在重写条件中,联合使用词典模式的“STRING“比较,就可以实现依赖于时间的重写: Rewri

23、teEngine onRewriteCond %TIME_HOUR%TIME_MIN 0700RewriteCond %TIME_HOUR%TIME_MIN ) s|foo/|bar/|;print $_;这是只是一个简单的示例,只是把所有的/quux/foo/.重写为/quux/bar/.而已。但事实上,可以把它修改成任何你想要的输出。但是要注意,虽然一般用户都可以使用,可是只有系统管理员才可以定义这样的映射。图 -1:重写规则集中的控制流 可见,URL 首先与每个规则的 Pattern 匹配,如果匹配失败,mod_rewrite 将立即终止此规则的处理,继而处理下一个规则。如果匹配成功,m

24、od_rewrite 将寻找相应的规则条件,如果一个条件都没有,则简单地用Substitution 构造的新值来替换 URL,然后继续处理其他规则;但是如果条件存在,则开始一个内部循环按其列出的顺序逐个处理。对规则条件的处理有所不同:URL 并不与模式进行匹配,而是首先通过扩展变量、反向引用、查找映射表等步骤建立一个 TestString 字符串,然后用它来与 CondPattern 匹配。如果匹配失败,则整个条件集和对应的规则失败;如果匹配成功,则执行下一个规则直到所有条件执行完毕。如果所有条件得以匹配,则以 Substitution 替换 URL,并且继续处理。高级 URL 重写指南本文是

25、 mod_rewrite 参考文档的补充材料。阐述在实际应用中如何解决网管所面临的基于 URL 的典型问题,并详细描述了如何配置 URL 重写规则集以解决这些问题。注意:根据你的服务器配置,有可能必须对这里的例子作些小修改,比如,在额外启用 mod_alias 和mod_userdir 的情况下要增加PT标志,或者为了适应目录级( .htaccess)的配置而将针对服务器级的规则集进行重写。对一个特定的规则集应该先透彻理解然后再考虑应用,这样才能避免出现问题。集群网站的同类 URL 规划描述: 我们希望在一个 Intranet 集群网站中,对所有 WWW 服务器建立一致的 URL 规划,也就是

26、说,所有的 URL(针对每个服务器进行本地配置,因此是独立于各个服务器的)实际上都是 独立于 各个服务器的!我们需要的是一个具有独立于各个服务器的一致性的 WWW 域名空间,即 URL 不需要包含物理目标服务器,而由集群本身来自动定位物理目标主机。 解决方案: 首先,目标服务器的信息来自于(分布式的) 包含有用户、组以及实体的外部映射表,其格式形如下: user1 server_of_user1user2 server_of_user2: :这些信息被存入 map.xxx-to-host 文件。其次,如果 URL 在一个服务器上无效,我们还需要引导所有的服务器将 /u/user/anypath

27、/g/group/anypath/e/entity/anypath重定向到 http:/physical-host/u/user/anypathhttp:/physical-host/g/group/anypathhttp:/physical-host/e/entity/anypath以下规则集依靠映射文件来完成这个操作(如果一个用户在映射表中没有对应的项,则使用server0 做为默认服务器): RewriteEngine onRewriteMap user-to-host txt:/path/to/map.user-to-hostRewriteMap group-to-host txt:/

28、path/to/map.group-to-hostRewriteMap entity-to-host txt:/path/to/map.entity-to-hostRewriteRule /u/(/+)/?(.*) http:/$user-to-host:$1|server0/u/$1/$2RewriteRule /g/(/+)/?(.*) http:/$group-to-host:$1|server0/g/$1/$2RewriteRule /e/(/+)/?(.*) http:/$entity-to-host:$1|server0/e/$1/$2RewriteRule /(uge)/(/+)

29、/?$ /$1/$2/.www/RewriteRule /(uge)/(/+)/(.+.+) /$1/$2/.www/$3结构化的用户主目录描述: 一些拥有几千个用户的网站通常都使用结构化的用户主目录规划,即每个用户主目录位于一个带有特定前缀(比如其用户名的第一个字符) 的子目录下:/foo/anypath 代表/home/f/foo/.www/anypath,而/bar/anypath 代表/home/b/bar/.www/anypath 解决方案: 可以使用下列规则集来扩展以达到上述目的。 RewriteEngine onRewriteRule /(a-z)a-z0-9+)(.*) /ho

30、me/$2/$1/.www$3文件系统的重组描述: 这是一个不加雕琢的例子:一个大量使用目录级规则集以实现平滑的观感,并且从来不用调整数据结构的杀手级的应用。背景:从 1992 年开始,net.sw 存放了我收集的免费 Unix 软件包。它是我的爱好也是我的工作,因为在学习计算机科学的同时,业余时间还做了多年的系统和网络管理员。每周我都需要整理软件,因而建立了一个层次很深的目录结构来存放各种软件包: drwxrwxr-x 2 netsw users 512 Aug 3 18:39 Audio/drwxrwxr-x 2 netsw users 512 Jul 9 14:37 Benchmark/

31、drwxrwxr-x 12 netsw users 512 Jul 9 00:34 Crypto/drwxrwxr-x 5 netsw users 512 Jul 9 00:41 Database/drwxrwxr-x 4 netsw users 512 Jul 30 19:25 Dicts/drwxrwxr-x 10 netsw users 512 Jul 9 01:54 Graphic/drwxrwxr-x 5 netsw users 512 Jul 9 01:58 Hackers/drwxrwxr-x 8 netsw users 512 Jul 9 03:19 InfoSys/drwxr

32、wxr-x 3 netsw users 512 Jul 9 03:21 Math/drwxrwxr-x 3 netsw users 512 Jul 9 03:24 Misc/drwxrwxr-x 9 netsw users 512 Aug 1 16:33 Network/drwxrwxr-x 2 netsw users 512 Jul 9 05:53 Office/drwxrwxr-x 7 netsw users 512 Jul 9 09:24 SoftEng/drwxrwxr-x 7 netsw users 512 Jul 9 12:17 System/drwxrwxr-x 12 netsw

33、 users 512 Aug 3 20:15 Typesetting/drwxrwxr-x 10 netsw users 512 Jul 9 14:08 X11/1996 年 7 月,我决定通过一个漂亮的 Web 接口公开我的收藏。“漂亮“是指提供一个直接浏览整个目录结构的接口,同时不对这个结构做任何改变,甚至也不在结构顶部放置 CGI 脚本。为什么呢?因为这个结构还要能够被 FTP 访问,而且我不希望其中有任何 Web 或者 CGI 成分。 解决方案: 这个方案分为两个部分:第一个部分是一组 CGI 脚本,用于实时建立所有目录层次的页面。我把它们放在/e/netsw/.www/中: -rw-

34、r-r- 1 netsw users 1318 Aug 1 18:10 .wwwacldrwxr-xr-x 18 netsw users 512 Aug 5 15:51 DATA/-rw-rw-rw- 1 netsw users 372982 Aug 5 16:35 LOGFILE-rw-r-r- 1 netsw users 659 Aug 4 09:27 TODO-rw-r-r- 1 netsw users 5697 Aug 1 18:01 netsw-about.html-rwxr-xr-x 1 netsw users 579 Aug 2 10:33 netsw-access.pl-rwx

35、r-xr-x 1 netsw users 1532 Aug 1 17:35 netsw-changes.cgi-rwxr-xr-x 1 netsw users 2866 Aug 5 14:49 netsw-home.cgidrwxr-xr-x 2 netsw users 512 Jul 8 23:47 netsw-img/-rwxr-xr-x 1 netsw users 24050 Aug 5 15:49 netsw-lsdir.cgi-rwxr-xr-x 1 netsw users 1589 Aug 3 18:43 netsw-search.cgi-rwxr-xr-x 1 netsw use

36、rs 1885 Aug 1 17:41 netsw-tree.cgi-rw-r-r- 1 netsw users 234 Jul 30 16:35 netsw-unlimit.lst其中的 DATA/子目录包含了上述目录结构,即实际的 net.sw 原始内容,由 rdist 在需要的时候自动更新。第二个部分的问题是:如何将这两个结构连接为一个观感平滑的 URL 树?我希望在为各种 URL 运行对应的 CGI 脚本的时候,用户感觉不到 DATA/目录的存在。方案如下:首先,我把下列配置放在针对每个目录的配置文件里,将公布的 URL“/net.sw/“重写为内部路径“/e/netsw“ : Rew

37、riteRule net.sw$ net.sw/ RRewriteRule net.sw/(.*)$ e/netsw/$1第一条规则是针对遗漏后缀斜杠的请求的!第二条规则才是真正实现功能的。接着,就是放在目录级配置文件/e/netsw/.www/.wwwacl 中的杀手级的配置了: Options ExecCGI FollowSymLinks Includes MultiViewsRewriteEngine on# 通过“/net.sw/“前缀到达RewriteBase /net.sw/# 首先将根目录重写到 cgi 处理脚本RewriteRule $ netsw-home.cgi LRewr

38、iteRule index.html$ netsw-home.cgi L# 当浏览器请求 perdir 页面时剥去子目录RewriteRule .+/(netsw-/+/.+)$ $1 L# 现在打断对本地文件的重写RewriteRule netsw-home.cgi.* - LRewriteRule netsw-changes.cgi.* - LRewriteRule netsw-search.cgi.* - LRewriteRule netsw-tree.cgi$ - LRewriteRule netsw-about.html$ - LRewriteRule netsw-img/.*$ -

39、 L# 任何别的东西都是一个由另一个 cgi 脚本处理的子目录RewriteRule !netsw-lsdir.cgi.* - CRewriteRule (.*) netsw-lsdir.cgi/$1阅读提示:1. 注意前半部分中的 L(最后)标志和非替换部分(-) 2. 注意后半部分中的!(非)符号和 C(链)标志 3. 注意最后一条规则是全匹配模式 将失败的 URL 重定向到其他 web 服务器描述: 一个常见的问题是如何将对 web 服务器 A 的失败请求重定向到服务器 B。一般,可以使用借助 ErrorDocument 的 CGI 脚本来解决,此外,还有使用 mod_rewrite 的

40、方案。但是须注意,这种方法的执行效率不如使用 ErrorDocument 的 CGI 脚本! 解决方案: 第一种方案,有最好的性能而灵活性欠佳,出错概率小所以安全: RewriteEngine onRewriteCond /your/docroot/%REQUEST_FILENAME !-fRewriteRule (.+) http:/webserverB.dom/$1但是问题在于,它只对位于 DocumentRoot 中的页面有效。虽然可以增加更多的条件 (比如同时还处理用户主目录,等等),但是还有一个更好的方法: RewriteEngine onRewriteCond %REQUEST_U

41、RI !-URewriteRule (.+) http:/webserverB.dom/$1这种方法使用了 mod_rewrite 提供的 “前瞻“(look-ahead)的功能,是一种对所有 URL 类型都有效而且安全的方法,但是对 web 服务器的性能有不利影响。如果 web 服务器有一个强大的 CPU,那就用这个方法。而在慢速机器上,可以用第一种方法,或者用性能更好的CGI 脚本。 文档访问的多路复用描述: 你知道 http:/ 的 CPAN(综合 Perl 存档网络) 吗?它实现了一个重定向以提供全世界的 CPAN 镜像中离访问者最近的 FTP 站点,也可以称之为 FTP 访问多路复用

42、服务。CPAN 是通过 CGI 脚本实现的,那么用 mod_rewrite 如何实现呢? 解决方案: 首先,mod_rewrite 从 3.0.0 版本开始可以重写“ftp:“类型。其次,可以用 RewriteMap取得对客户端顶级域名的最短路径。利用链式规则集,并用顶级域名作为查找多路复用映射表的键,可以这样做: RewriteEngine onRewriteMap multiplex txt:/path/to/map.cxanRewriteRule /CxAN/(.*) %REMOTE_HOST:$1 CRewriteRule .+.(a-zA-Z+):(.*)$ $multiplex:$

43、1|ftp.default.dom$2 R,L# map.cxan - CxAN 多路映射表#de ftp:/ftp.cxan.de/CxAN/uk ftp:/ftp.cxan.uk/CxAN/com ftp:/ 有时候有必须提供依赖于浏览器的最佳内容(至少对重要的顶级页面) ,即对最新的 Netscape提供最大化的版本,对 Lynx 提供最小化的版本,而对其他的浏览器则提供一个一般的版本。解决方案: 对此,内容协商无能为力,因为浏览器不提供那种形式的类型,所以只能在“User-Agent“头上想办法。以下规则集可以完成这个操作:如果“User-Agent“以“Mozilla/3“开头,则将

44、foo.html 重写为 foo.NS.html,并终止重写操作;如果是“Lynx“或者版本号为 1 和 2 的“Mozilla“,则重写为 foo.20.html;而对其他所有浏览器则是 foo.32.html。 RewriteCond %HTTP_USER_AGENT Mozilla/3.*RewriteRule foo.html$ foo.NS.html LRewriteCond %HTTP_USER_AGENT Lynx/.* ORRewriteCond %HTTP_USER_AGENT Mozilla/12.*RewriteRule foo.html$ foo.20.html LRe

45、writeRule foo.html$ foo.32.html L动态镜像描述: 假定,需要在我们的域名空间里加入其他远程主机的页面。对 FTP 服务器,可以用 mirror程序在本地机器上维持一个对远程数据的最新的拷贝;对 HTTP 服务器,可以使用webcopy 程序。但这两种技术都有一个主要的缺点:本地拷贝必须通过这个程序来更新。所以,比较好的方法是不采用静态镜像,而采用动态镜像,即在有数据请求时自动更新(远程主机上更新的数据)。 解决方案: 为达到此目的,可以使用 代理吞吐 (Proxy Throughput)功能( P标志) ,将远程页面甚至整个远程网络区域映射到我们的域名空间: R

46、ewriteEngine onRewriteBase /quux/RewriteRule hotsheet/(.*)$ http:/ PRewriteEngine onRewriteBase /quux/RewriteRule usa-news.html$ http:/www.quux- P反向动态镜像描述: . 解决方案: RewriteEngine onRewriteCond /mirror/of/remotesite/$1 -URewriteRule http:/ /mirror/of/remotesite/$1通过 Intranet 取得丢失的数据描述: 这在受防火墙保护的内部网(www2.quux-corp.dom) 上保存和维护实际数据,而在 Internet上虚拟地运行 web 服务器(www.quux-corp.dom)。方法是外部服务器在空闲时间从内部服务器取得被请求的数据。 解决方案: 首先,必须确保防火墙对内部服务器的保护,并只

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报