1

我们在 Azure 中托管了一个 ASP.NET 站点。

之前我们实现了以下重写规则来强制 HTTPS:

  <rules>
    <rule name="Redirect to https">
      <match url="(.*)"/>
      <conditions>
        <add input="{HTTPS}" pattern="Off"/>
        <add input="{REQUEST_METHOD}" pattern="^get$|^head$|^post$" />
      </conditions>
      <action type="Redirect" url="https://{HTTP_HOST}/{R:1}"/>
    </rule>
  </rules>

我们现在通过以下规则(来自本指南)引入 HSTS:

  <outboundRules>
    <rule name="Add Strict-Transport-Security only when using HTTPS" enabled="true">
      <match serverVariable="RESPONSE_Strict_Transport_Security" pattern=".*" />
      <conditions>
        <add input="{HTTPS}" pattern="on" ignoreCase="true" />
      </conditions>
      <action type="Rewrite" value="max-age=31536000; includeSubdomains; preload" />
    </rule>
  </outboundRules>

我们是否需要两条规则,还是可以删除 HTTPS 规则而只使用 HSTS 规则?

4

1 回答 1

4

不,你需要两者。

HSTS 应仅应用于符合规范的安全请求。将它应用于不安全的请求是没有意义的,因为中间人可能只是剥离标题。

如果请求来自 HTTP,您必须首先将它们重定向到 HTTPS。然后在响应中返回 HSTS 标头。

引用规范:https ://www.rfc-editor.org/rfc/rfc6797#section-7.2

HSTS 主机不得在通过非安全传输传送的 HTTP 响应中包含 STS 头字段。

于 2017-06-20T09:40:07.130 回答