我有一个支持 HTTPS 的网站:http ://example.com/foo 形式的所有页面都可以作为https://example.com/foo访问(查询将返回相同的内容)。也就是说,该网站不包含任何机密信息,因此使用 HTTPS 并没有很大的好处。
我想宣传该网站的HTTPS版本的存在,但我不想强迫人们使用它:一些老客户端可能不支持它,一些高级用户可能不喜欢它,等等。为此原因我不希望服务器通过重定向来回答未加密的 HTTP 请求。也就是说,对于喜欢使用 HTTPS 的用户,必须有一种方法让他们发现支持 HTTPS。(Web 浏览器不会主动尝试将 HTTP 连接升级到 HTTPS,例如,因为某些网站通过 HTTPS 提供的内容与通过 HTTP 提供的内容不同。)
Web 服务器有没有办法在不要求客户端使用 HTTPS 的情况下宣传支持 HTTPS(即,任何请求都可以使用 HTTPS 而不是 HTTP 完成)?
我发现的唯一相关机制是Upgrade: TLS/1.0
来自RFC2817的标头,它显然可以由服务器和客户端发送。但对我来说,这似乎并不明显,它是常用的还是 Web 浏览器支持的。
以下不是 HTTPS 特定的,但可用于软引导客户端使用 HTTPS。
如果您在多个 URL 下提供相同的内容(如果您允许 HTTP 和 HTTPS,就是这种情况),您应该为您提供的内容添加一个规范标签。然后,该规范标签标识访问内容的首选方式。
让我们假设您拥有“example.com”并为此托管一个网站。可以使用 HTTP 和 HTTPS 访问该站点,包括“example.com”和“www.example.com”,主页位于“/”和“/default.html”下(无论您可能有什么历史原因)。因此可以使用访问主页
然后,您决定默认情况下每个人都应使用https://www.example.com/default.html访问您网站的主页,但您不想添加任何重定向。
您可以将以下标签添加到您的主页
<head>
部分这将告诉每个网络爬虫(即 google)和浏览器,它现在正在查看的内容在该 url 上可用。然后,客户端软件本身可以决定如何处理该信息。
缺点是您必须为您提供的每个 HTML 文档添加这样的标签,并且它仅适用于 HTML。
作为 rel="canonical" 机制的替代方案,现在常见的解决方案似乎是使用“Upgrade-Insecure-Requests: 1”标头(显然是在发出普通 HTTP 请求时由 Firefox 和 Chrome 发送的)。这就是这些客户端宣传它们支持 HTTPS 的方式,然后服务器应将它们重定向到 HTTPS 版本。
有关使其与 lighttpd 一起使用的问题,请参见此处。