首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ASP.NET HTTPS重定向& HSTS报头

ASP.NET HTTPS重定向& HSTS报头
EN

Stack Overflow用户
提问于 2017-06-20 09:38:44
回答 1查看 2.3K关注 0票数 1

我们有一个ASP.NET网站托管在Azure。

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

代码语言:javascript
复制
  <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:

代码语言:javascript
复制
  <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规则?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-06-20 09:40:07

不,你两者都需要。

HSTS只应应用于根据规范保护请求。将其应用于不安全的请求是没有意义的,因为中间的人可以直接删除标题。

如果请求与HTTP一起出现,则必须首先将它们重定向到HTTPS。然后在响应中返回HSTS头。

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

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

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44649334

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档