.htaccess - 在一次重定向中重定向到 HTTPS 和 WWW
问题描述
对于我的网站,我设置了 CloudFlare CDN。该网站托管在 Siteground 上。CloudFlare 要求将网站重定向到 www。
现在我在 htaccess 文件中设置了重定向。它将所有非 https 和非 www 请求重定向到 https-www 版本。
以下是我在 htaccess 文件中使用的规则:
RewriteEngine on
RewriteCond %{HTTP_HOST} !^www\. [OR]
RewriteCond %{HTTPS} off
RewriteCond %{HTTP_HOST} ^(?:www\.)?(.+)$ [NC]
RewriteRule ^ https://www.%1%{REQUEST_URI} [NE,L,R=301]
重定向工作正常。我唯一的问题是它需要 2 个重定向。假设我的网站是 example.com。
当我打开 example.com 时,它首先重定向到https://example.com,然后重定向到https://www.example.com
因此,我在两次重定向后得到响应代码。301-301-200
现在我的问题是:有没有办法在一个重定向中完成它?
解决方案
您需要动态主机名吗?如果不是(听起来像),您可以简化:如果不是 www 或不是 https,则重定向到 https/www。如果主机名是静态的,则不需要从条件中获取它。您可以在重定向规则中按字面意思命名它:
RewriteEngine on
RewriteCond %{HTTP_HOST} !^www\. [OR]
RewriteCond %{HTTPS} off
RewriteRule ^ https://www.example.com{REQUEST_URI} [QSA,R=301,END]
最好先从 302 临时重定向开始,然后再将其更改为 301 永久重定向,前提是您确定一切都已正确设置。这可以防止在尝试时出现缓存问题......
如果您使用上述规则收到内部服务器错误(http 状态 500),那么您很可能操作的是非常旧版本的 apache http 服务器。[END]
在这种情况下,您将在您的 http 服务器错误日志文件中看到明确提示不支持的标志。您可以尝试升级或使用较旧的[L]
标志,在这种情况下它可能会起作用,尽管这取决于您的设置。
此实现同样适用于 http 服务器主机配置或分布式配置文件(“.htaccess”文件)。显然重写模块需要在http服务器内部加载并在http主机中启用。如果您使用分布式配置文件,您需要注意它的解释在主机配置中完全启用,并且它位于主机的DOCUMENT_ROOT
文件夹中。
和一般性评论:您应该始终喜欢将此类规则放在 http 服务器主机配置中,而不是使用分布式配置文件(“.htaccess”)。这些分布式配置文件增加了复杂性,通常是意外行为的原因,难以调试,而且它们确实减慢了 http 服务器的速度。它们仅在您无法访问真正的 http 服务器主机配置(阅读:非常便宜的服务提供商)或坚持编写自己的规则的应用程序(这是一个明显的安全噩梦)的情况下作为最后一个选项提供。
推荐阅读
- oracle-cloud-infrastructure - Oracle Cloud 始终免费套餐。我有资格吗?
- sql - 无法在 MS Access 的外键字段中插入空值
- python - 尝试将 Dictionary 转换为 DataFrame Pandas 时出现 ValueError
- javascript - 用户输入有时会破坏 REGEX
- sql - Google Big Query:基于当前行条件的聚合新列
- c# - 使用 NoSQL 数据库进行 ASP.NET Core 身份验证
- android - Android Kotlin Coroutine 崩溃,但没有在 Logcat 中报告致命错误
- python-3.x - 我如何计算python文件中的空白行
- rust - Rust 第一步,如何创建 Option
> 来自 &mut 自我? - python - 如何通过这个基本计算脚本使用 OOP?