通过强制执行特定的标头值来webpack-dev-server
尝试减轻哪些安全风险?Host
默认情况下,webpack-dev-server
仅允许Host
标头指定本地环回地址(localhost
、、127.0.0.1
等)的连接。所有其他主机都会收到此响应:“无效的主机标头”。但是当然--allowed-hosts
/allowedHosts
配置允许扩大这个限制。
这似乎仅基于Host
标题。我可以使用 curl 设置自定义 Host 标头,并且请求成功:
curl -X GET -H "Host: http://0.0.0.0:9001/" http://me.internal.example.com:9001/
所以我很好奇——如果allowedHosts
不阻止来自 curl 或其他自定义用户代理的连接,它解决了什么问题?它似乎只针对使用普通浏览器的普通用户,以保护他们免受在错误主机上提供的站点的影响。但是中间人攻击可以很容易地代理连接并覆盖主机标头。
为了防止 MITM 攻击,您可以使用 https(带有浏览器信任的证书)。但在这种情况下,证书本身似乎可以减轻 MITM 攻击。
我确定我遗漏了一些东西,所以任何进一步的解释表示赞赏。