首页 > 解决方案 > 将一个子目录重写为另一个子目录

问题描述

我正在尝试获取http://example.com/api/dev/v1/warehouse/要重写的 URL:http://example.com/api/v1/warehouse/

第一个 URL 中的“dev”目录不存在。第二个 URL 存在。

本质上,当访问者访问第一个 URL 时,它应该重写(而不是重定向)到第二个 URL。它还应该重写所有子目录。

我尝试了以下方法:

  RewriteEngine on
  RewriteRule ^/?api/dev/v1/(.*)$ /api/v1/$1 [L]


  RewriteEngine on
  RewriteRule ^/api/v1/(.*)$ /api/dev/v1/$1 [L]


  RewriteEngine on
  RewriteRule ^/?api/dev/v1/(.*)$ /api/v1/$1 [L]


  RewriteEngine on
  RewriteRule !^api/dev/v1(/|$) api/v1%{REQUEST_URI} [L]

但他们都给了404....

补充一点,.htaccess 文件位于根目录,htaccess 文件中没有其他内容。

标签: .htaccessmod-rewrite

解决方案


这看起来很简单,实际上:

RewriteEngine on
RewriteRule ^/?api/dev/v1/(.*)$ /api/v1/$1 [END]

如果您使用上述规则收到内部服务器错误(http 状态 500),那么您很可能操作的是非常旧版本的 apache http 服务器。[END]在这种情况下,您将在您的 http 服务器错误日志文件中看到明确提示不支持的标志。您可以尝试升级或使用较旧的[L]标志,在这种情况下它可能会起作用,尽管这取决于您的设置。

此实现同样适用于 http 服务器主机配置或动态配置文件(“.htaccess”文件)。显然重写模块需要在http服务器内部加载并在http主机中启用。如果您使用动态配置文件,您需要注意它的解释在主机配置中完全启用,并且它位于主机的DOCUMENT_ROOT文件夹中。

和一个一般性评论:您应该始终更喜欢将此类规则放在 http 服务器主机配置中,而不是使用动态配置文件(“.htaccess”)。这些动态配置文件增加了复杂性,通常是意外行为的原因,难以调试,而且它们确实减慢了 http 服务器的速度。它们仅在您无法访问真正的 http 服务器主机配置(阅读:非常便宜的服务提供商)或坚持编写自己的规则的应用程序(这是一个明显的安全噩梦)的情况下作为最后一个选项提供。

为此,显然需要将重写模块加载到 http 服务器中。此外,如果您决定使用动态配置文件(“.htaccess”样式文件),尽管我在上面解释过,那么您需要为请求的位置启用此类文件的解释(AllowOverride在 apache 文档中查找)。该文件需要放在DOCUMENT_ROOT响应请求的http主机的文件夹中,并且需要http服务器进程可以读取。当然,它需要有有效的语法。如果所有这些都给出了,但仍然无法正常工作,那么您绝对应该查看您的 http 服务器的错误日志文件。那是引擎将记录它遇到的所有问题的地方。在 Web 环境中进行实现时,无论如何您都需要监视该文件,


推荐阅读