我的.htaccess文件中有这个:
RewriteCond %{HTTP_HOST} ^example.com$
RewriteRule (.*) http://www.example.com$1 [R=301,L]
但每当我访问根目录下的文件,比如http://example.com/robots.txt,它就会重定向到http://www.example.comrobots.txt/。
我如何纠正这一点,使它将正确重定向到http://www.example.com/robots.txt?
两个警告
避免301,使用现代303或307响应状态码。
避免301
如果您真的需要指示为[R=301]的永久重定向,请仔细考虑,因为如果您决定稍后更改它,那么该页面的先前访问者将继续看到原始重定向的页面。
永久重定向信息经常存储在浏览器的缓存中,通常很难消除(重新加载页面不能解决问题)。你的网站访问者将永远停留在之前的重定向中。
也不要使用302
HTTP协议的新版本(v1.1)添加了两个新的响应状态码,可以用来代替302。
URL重定向,但要求更改请求类型为
得到的。
307 URL重定向,但要求保持最初发送的请求类型。
您仍然可以使用代码302(非永久重定向),尽管它被认为是不明确的。在任何情况下,大多数浏览器都以新的303代码指示的相同方式实现302。
我相信顶部的答案成功地重定向非www到www(例如:mysite.com -> www.mysite.com),但不考虑通配符子域,这导致:
random.mysite.com -> www.random.mysite.com
这里有一个有/没有HTTPS的解决方案
HTTP
RewriteEngine On
RewriteCond %{HTTP_HOST} !www.mysite.com$ [NC]
RewriteRule ^(.*)$ http%{ENV:protossl}://www.mysite.com/$1 [L,R=301]
使用HTTP / HTTPS
RewriteEngine On
RewriteCond %{HTTPS} =on
RewriteRule ^(.*)$ - [env=protocol:https]
RewriteCond %{HTTPS} !=on
RewriteRule ^(.*)$ - [env=protocol:http]
RewriteCond %{HTTP_HOST} !www.mysite.com$ [NC]
RewriteRule ^(.*)$ %{ENV:protocol}://www.mysite.com/$1 [L,R=301]
*注:我还没有测试https,因为我目前没有一个证书来测试,但如果有人可以验证或优化我所拥有的,那就太棒了。