基本上我想要的是redirect请求使用HTTPS而不是http
我有这个在我的htaccess到目前为止,它的工作很好:代码:
<IfModule mod_rewrite.c> RewriteEngine On RewriteCond %{HTTPS} off RewriteRule (.*) https://%{HTTP_HOST}%{REQUEST_URI} </ifModule>
今天有人注意到,当去: http : //www.example.com它redirect到并显示一个不安全的连接thingie。
我的ssl设置为非www域:mydomain.com
如何确定redirect到https的位置正在发生
如何将httpredirect到https和https:// www到https://
将非WWWredirect到WWW URL
.htaccess与片段redirect
用.htaccess将一个特定的urlredirect到另一个url
所以我需要确保所有网站的请求被发送到非www和https:它工作正常,如果我把example.com它redirect到https://example.com
但通过www.example.com进入htts://www.example.com并显示错误
我需要添加到我的代码redirectwww到非www然后到ssl?
.Htaccess – 服务器错误
.htaccess重写规则改变下划线破折号
htaccess在localhost中工作,但在EC2实例中不起作用
apache HTTP:X-Forwarded-Proto in .htaccess在开发环境中导致redirect循环
你可以从HTTP_HOST获得你所需要的
RewriteEngine On RewriteCond %{HTTPS} off RewriteCond %{HTTP_HOST} ^(?:www.)?(.*)$ [NC] RewriteRule (.*) https://%1%{REQUEST_URI} [L,R=301]
这样一来,主机总是没有子域名。
您将不得不重新签发你的证书,无论是www还是没有www。
如果有人通过不包含在您的通用名称中的域名连接到您的网站,他们将收到警告。
ssl协商过程发生在来自服务器的任何响应之前 (在你的情况下,重定向),所以在所有情况下,访问者在使用非通用名称的域名时将收到警告。
RewriteEngine On RewriteCond %{HTTPS} off RewriteRule (.*) https://domain.com%{REQUEST_URI} [L,R=301,NC] RewriteCond %{HTTP_HOST} ^www.domain.com [NC] RewriteRule (.*) https://domain.com%{REQUEST_URI} [L,NC]
如果您使用CloudFlare的免费帐户,那就是问题所在。 CloudFlare的免费帐户不支持SSL证书。 要通过SSL证书继续使用CloudFlare的免费帐户,只需转到CloudFlare中的DNS设置,然后从您的域中取走橙色云,然后关闭cname WWW。 这将解决您的问题,并导致www和非www被重定向到https。
RewriteEngine On RewriteCond %{HTTPS} !=on RewriteRule ^ https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301]
那么,一切都应该工作!
RewriteEngine On RewriteCond %{HTTPS} off RewriteCond %{HTTP_HOST} ^(?:www.)?(.*)$ [NC] RewriteRule (.*) https://www.%1%{REQUEST_URI} [L,R=301]