欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

Apache RewriteBase 指令使用介绍

程序员文章站 2022-06-28 23:44:26
rewritebase url-path rewritebase用于设定重写的基准url。在下文中,你可以看见rewriterule可以用于目录级的配置文件中 (.h...

Apache RewriteBase 指令使用介绍

rewritebase url-path

rewritebase用于设定重写的基准url。在下文中,你可以看见rewriterule可以用于目录级的配置文件中 (.htaccess)并在局部范围内起作用,即规则实际处理的只是剥离了本地路径前缀的一部分。处理结束后,这个路径会被自动地附着回去。默认值 是”rewritebase physical-directory-path”。
在对一个新的url进行替换时,此模块必须把这个url重新注入到服务器处理中。为此,它必须知道其对应的url前缀或者说url基准。通常,此前缀就是 对应的文件路径。但是,大多数网站url不是直接对应于其物理文件路径的,因而一般不能做这样的假定! 所以在这种情况下,就必须用rewritebase指令来指定正确的url前缀。
如果你的网站服务器url不是与物理文件路径直接对应的,而又需要使用rewritebase指令,则必须在每个对应的.htaccess文件中指定 rewriterule 。

rewritebase指令显式地设置了目录级重写的基准url。在下文中,你将看到rewriterule可以用于目录级的配置文件中(.htaccess)并在局部范围内起作用,即规则实际处理的只是剥离了本地路径前缀的一部分。处理结束后,这个路径会被自动地附着回去。默认值是"rewritebasephysical-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/defrewritebase   /xyz
# 重写规则rewriterule   ^oldstuff\.html$  newstuff.html

上述例子中,对/xyz/oldstuff.html的请求被正确地重写为对物理文件/abc/def/newstuff.html的请求。

仅供apache hacker们参考

以下列出了内部处理的详细步骤:

请求:  /xyz/oldstuff.html内部处理过程:  /xyz/oldstuff.html     -> /abc/def/oldstuff.html  (per-server alias)  /abc/def/oldstuff.html -> /abc/def/newstuff.html  (per-dir    rewriterule)  /abc/def/newstuff.html -> /xyz/newstuff.html      (per-dir    rewritebase)  /xyz/newstuff.html     -> /abc/def/newstuff.html  (per-server alias)

结果:  /abc/def/newstuff.html

虽然这个过程看来很繁复,但是由于目录级重写的到来时机已经太晚了,它不得不把这个(重写)请求重新注入到 apache核心中,所以apache内部确实是这样处理的。但是:它的开销并不象看起来的那样大,因为重新注入完全在apache服务器内部进行,而且这样的过程在apache内部也为其他许多操作所使用。所以,你可以充分信任其设计和实现是正确的。