Apache伪静态资料.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Apache伪静态资料

Apache伪静态资料 ? Apache模块 mod_rewrite 说 明 一个基于一定规则的实时重写URL请求的引擎 状 态 扩展(E) 模 块名 rewrite_module 源 文件 mod_rewrite.c 兼 容性 仅在 Apache 1.3 及以后的版本中可用 概述 此模块提供了一个基于正则表达式分析器的重写引擎来实时重写URL请求。它支持每个完整规则可以拥有不限数量的子规 则以及附加条件规则 的灵活而且强大的URL操作机制。此URL操作可以依赖于各种测试,比如服务器变量、环境变量、 HTTP头、时间标记,甚至各种格式的用于匹配URL组成 部分的查找数据库。 此模块可以操作URL的所有部分(包括路径信息部分),在服务器级的(httpd.conf)和目录级的(.htaccess) 配置都有效, 还可以生成最终请求字符串。此重写操作的结果可以是内部子处理,也可以是外部请求的转向,甚至还可以是内部代理处 理。 但是,所有这些功能和灵活性带来一个问题,那就是复杂性,因此,不要指望一天之内就能看懂整个模块。 更多的讨论、细节、示例,请查看详细的URL ? ?重写文档 ? 。 特殊字符的引用 在Apache 1.3.20中,TestString和Substitution中的特殊字符 可以用前导斜杠(/)来实现转义(即忽略其特殊含义而视之为普通 字符)。 比如,Substitution可以用/$ 来包含一个美元符号,以避免mod_rewrite把它视为反向引用。 环境变量 此模块会跟踪两个额外的(非标准)CGI/SSI环境变量,SCRIPT_URL和SCRIPT_URI。 他们包含了当前资源的逻辑网络视 图,而标准CGI/SSI变量SCRIPT_NAME和SCRIPT_FILENAME包 含的是物理系统视图。 注意:这些变量保持的是其最初被请求时的URI/URL,即在任何重写操作之前的 URI/URL。其重要性在于他们是重写操 作重写URL到物理路径名的原始依据。 示例 SCRIPT_NAME=/sw/lib/w3s/tree/global/u/rse/.www/index.html SCRIPT_FILENAME=/u/rse/.www/index.html SCRIPT_URL=/u/rse/ SCRIPT_URI=/u/rse/ 实用方案 我们提供了URL ? ?重写指南 ? 和高 级 ? ? ? ?URL ? ? ? ?重写指南 ? 文档,列举了许多基于URL的问题的实用方案,其中你可以找到真实有 用的规则集。 RewriteBase 指 令 说 明 设置目录级重写的基准URL 语 法 RewriteBase URL-path 默 认值 参见使用方法 作 用域 directory, .htaccess 覆 盖项 FileInfo 状 态 扩展(E) 模 块 mod_rewrite RewriteBase指令显式地设置了目录级重写的基准URL。在 下文中,你将看到RewriteRule ?可 以用于目录级的配置 文件中(.htaccess)并在局部范围内起作用,即规则实际处理的只是剥离了本地路径前缀的一部分。处 理结束后,这个 路径会被自动地附着回去。默认值是RewriteBase physical-directory-path。在对一个新的URL进行替换时,此模块必须把这个URL重新注入到服务器处理中。为此,它必须知道其对应的URL前缀 或者说URL基 准。通常,此前缀就是对应的文件路径。但是,大多数网站URL不是直接对应于其物理文件路径的,因而 一般不能做这样的假定! 所 以在这种情况下,就必须用RewriteBase指令来指定正确的URL前缀。 如果你的网站服务器URL不是与物理文件路径直接对应的,你必须在每个使用RewriteRule ?的.htaccess文 件中使用 RewriteBase指令。 例如,目录级配置文件内容如下: # /abc/def/.htaccess -- /abc/def 目录的配置文件 # 注意:/abc/def 是 /xyz 的物理路径(例如存在一条Alias /xyz /abc/def指令)。 RewriteEngine On # 让服务器知道我们使用的是 /xyz 而不是物理路径 /abc/def RewriteBase ? /xyz # 重写规则 RewriteRule ? ^oldstuff/.html$ ?newstuff.html 上述例子中,对/xyz/oldstuff.html的请求被正确地重写为对物理文件/abc/def/newstuff.html的 请求。 仅供Apache Hacker们参考 以下列出了内部处理的详细步骤: 请求: ??/xyz/oldstuf

文档评论(0)

yan698698 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档