如何解决使用.htaccess从2个不同的子文件夹运行2个drupal站点
我有一个example.com域,为此我创建了两个完全独立的drupal 8安装程序。这两个不同的设置位于根目录下的两个不同子文件夹中,即build1和build2。
A。我想将任何网址自动转换为https。 B.我想自动将www添加到没有www的任何URL。 C.当用户访问URL example.com时,我希望请求重定向并打开子文件夹build1中的drupal站点,而不会在URL中显示build1子文件夹的名称。
通过在根文件夹的.htaccess中使用以下命令,我已经获得了A,B和C。
RewriteEngine On
RewriteCond %{HTTPS} off
RewriteRule ^(.*)$ https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301]
RewriteEngine on
RewriteCond %{HTTP_HOST} !^www\.
RewriteRule ^(.*)$ http://www.%{HTTP_HOST}/$1 [R=301,L]
RewriteEngine on
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ build1/$1 [L]
我正在努力的下一个目标是在.htaccess中添加指令,以便当我键入example.com/build2或www.example.com/build2时,它会打开build2中的drupal设置。
我尝试了一段时间,但没有运气。
预先感谢...。麦克风
解决方法
您需要在常规捕获所有规则之前添加 例外,因此请在分布式配置文件中进一步查找:
RewriteEngine On
RewriteCond %{HTTPS} off
RewriteRule ^ https://%{HTTP_HOST}%{REQUEST_URI} [R=301,END]
RewriteCond %{HTTP_HOST} !^www\.
RewriteRule ^ http://www.%{HTTP_HOST}%{REQUEST_URI} [R=301,END]
RewriteRule ^/?build2 - [END]
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^ build1/%{REQUEST_URI} [END]
根据设置的其余部分(此处不清楚),您可能需要先保护对现有文件夹的请求,然后再重写到那些应用程序中。视书面情况而定...
RewriteEngine On
RewriteCond %{HTTPS} off
RewriteRule ^ https://%{HTTP_HOST}%{REQUEST_URI} [R=301,END]
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^ - [END]
RewriteRule ^/?build2 - [END]
RewriteRule ^ build1/%{REQUEST_URI} [END]
一个好的主意是从302临时重定向开始,然后在确定一切正确设置之后,才将其更改为301永久重定向。这样可以防止在尝试时缓存问题...
如果使用上述规则收到内部服务器错误(http状态500),则很可能是您运行了非常旧版本的apache http服务器。在这种情况下,您将在http服务器错误日志文件中看到对不支持的[END]
标志的明确提示。您可以尝试升级,也可以使用较旧的[L]
标志,尽管在某种程度上取决于您的设置,但是在这种情况下它可能会起作用。
此实现将在http服务器主机配置或分布式配置文件(“ .htaccess”文件)中同样起作用。显然,重写模块需要加载到http服务器内部并在http主机中启用。如果您使用分布式配置文件,则需要注意在主机配置中完全启用了它的解释功能,并且该文件位于主机的DOCUMENT_ROOT
文件夹中。
还有一个一般性说明:您应该始终喜欢将此类规则放置在http服务器主机配置中,而不要使用分布式配置文件(“ .htaccess”)。这些分布式配置文件增加了复杂性,通常是导致意外行为,难以调试的原因,并且确实降低了http服务器的速度。仅当您无法访问真正的http服务器主机配置(阅读:真正便宜的服务提供商)或坚持编写自己的规则的应用程序(这显然是安全的噩梦)时,才提供它们作为最后的选择。 / p>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。