4

这是我到目前为止所拥有的:

#Force www.
RewriteCond %{HTTPS} !=on
RewriteCond %{HTTP_HOST} !^www\..+$ [NC]
RewriteRule ^ http://www.%{HTTP_HOST}%{REQUEST_URI} [R=301,L]

#Remove trailing slash
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_URI} (.*)$
RewriteRule ^(.+)/$ http://www.domain.com/$1 [R=301,L]

但是,这会弄乱所有执行以下重定向的子域:

sub.domain.com -> www.sub.domain.com

而且,它依赖于写在删除斜杠位上的域。

所以......两个问题。

如何重写“删除尾部斜杠”位上的规则以排除在其上写入域?

如何在“强制 www”上进行重写以排除子域,而无需明确写下它们。少量?

期望结果的例子 -

sub.domain.com/something/ -> sub.domain.com/something
domain.com/something/ -> www.domain.com/something
www.domain.com/ -> www.domain.com
sub.domain.com -> sub.domain.com

谢谢!

4

1 回答 1

7

更改 www 以检查实际域:

#Force www.
RewriteCond %{HTTPS} !=on
RewriteCond %{HTTP_HOST} ^domain\.com$ [NC]
RewriteRule ^ http://www.%{HTTP_HOST}%{REQUEST_URI} [R=301,L]

或者,如果您托管大量域,则可以在 TLD 之前检查名称:

RewriteCond %{HTTPS} !=on
RewriteCond %{HTTP_HOST} ^([^.]+)\.([a-z]{2,4})$ [NC]
RewriteRule ^ http://www.%1.%2%{REQUEST_URI} [L,R=301]

至于结尾的斜杠,您必须小心不要为目录发出请求。因为如果是,并且您已经DirectorySlash打开(默认情况下它是打开的),那么您将导致重定向循环。

为了排除子域,我们假设第一条规则重定向浏览器以确保它以“www”开头,并且由于子域没有被重定向为以“www”开头,我们可以检查一下:

#Remove trailing slash
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{HTTP_HOST} ^www\. [NC]
RewriteRule ^(.+)/$ /$1 [R=301,L]
于 2013-03-01T22:12:56.043 回答