原文链接 :https://www.usenix.org/system/files/sec21-dai.pdf
参考阅读:http://www.hackdig.com/09/hack-486357.htm
相较于一般的DNS投毒攻击,本篇论文作者聚焦于针对互联网资源供应商们的DNS投毒攻击。历史攻击事件表明,网络攻击者能够通过对供应商的DNS投毒,控制目标资源所有者在该供应商网站的账号(例如IP 地址管理域注册商、IaaS提供商的虚拟机资源以及证书颁发机构),并以此控制账号相关的资源。在本篇论文中,作者团队首次展示了劫持供应商平台的帐户并开展路径外攻击以接管其网络资源,攻击者可至少控制至少68%的ipv4地址和31%的Alexa顶级域名。
DNS缓存投毒攻击(旁路劫持)可以分为三种方法,成功率是第一个和第三个比较高(?):
第一,BGP前缀劫持。【人们通常觉得短时间的流量变化是由于配置错误引起,对网络负载无影响,可以忽略,因此常常忽视对BGP前缀劫持攻击的追踪。故比较隐蔽。】
攻击者对受害AS声称一个ip前缀(目标网络所在的网络),在DNS请求之后进行响应,从而注入恶意DNS记录,之后进行密码重置、释放BGP劫持、控制账户等操作。
第二,侧信道端口推理。 思路为:使用ICMP侧信道猜测受害DNS解析器在查询目标服务器使用的UDP端口。1)向DNS解析器发送udp包,验证icmp端口不可达;2)向DNS解析器关闭着的端口发送50个用于欺骗的udp包和1个非欺骗的udp包。此时 ,如果存在icmp全局速率限制,则不会受到任何消息;3)点击重置密码按钮,触发DNS请求;4)替代真实DNS解析器(make it dumb),运行程序暴力推断DNS请求源端口。5)找到源端口后,为每个可能的TXID发送2^16个欺骗响应,映射域名和攻击者的IP。6)重置密码成功,控制账户。或者,使用SadDNS进行端口扫描,每个元组30min,但是具有很高的失败率,所以需要改进这一个攻击方法。
第三,IP碎片整理缓存注入。 思路为:片段重组。发送一个恶意片段,该片段覆盖了第二个片段,与DNS解析器的第一个真正的片段进行了重组。这样,重组后的ip报文既包含了真实的DNS记录,又包含恶意IP的映射片段,由于质询值(端口、TXID-transaction Id)在第一个片段中,所以该重组片段会被认为是一个正确合理的片段。从第二个片段进入DNS解析器进行重组,到DNS解析器的真正的第一个碎片到达的时刻,总时间不应超过15秒。实践证明,15秒足以发动攻击。从通过web界面触发密码恢复过程到DNS请求到达攻击者服务器,测量的延迟时间如下:
假设攻击者需要攻击某网络基础设施,其首先收集该基础设施的信息(设施供应商,控制者账号、控制者邮箱等)。收集目标provider、client的数据,分析各provider的密码恢复机制;收集provider的DNS解析器地址;找到ip地址,用于请求恢复密码时查找客户的Email服务器。攻击能够奏效的情况下,为了真正实现上述攻击方式,几种信息至关重要:目标用户名、绑定邮箱、供应商DNS服务器,作者分别对这些信息的收集给出方法。
一方面,对于用户名、邮箱这类用户信息,可以从公共whois记录进行检索到。在实验中,相当一部分的账户及邮箱可以直接通过whois记录检索。此外,作者还结合一些公开的字典对用户信息进行爆破,有部分撞库操作在里面,效果也不错。
另一方面,为了获得供应商的DNS服务器信息,攻击者自己搭建域名服务和邮件服务,然后在供应商网站注册账号并发起重置密码请求。为了获取邮件服务器的地址,供应商的DNS服务器需要向攻击者的域名服务发起查询请求。随后攻击者记录这些请求,从而得知供应商的域名服务器信息,以便发动后续的投毒攻击。
图1:攻击者向DNS解析器投毒->攻击者在web网站上点击忘记密码,web网站会给邮件服务器发送重置密码邮件,邮件服务器进行DNS查询,进而解析到攻击者的IP地址->攻击者邮箱收到密码重置链接,登入账户,开始控制网络资产。
由于是实验,不能真的劫持外部网站,所以从攻击者账户到AS到IP地址都要自己买。
具体氪金行为 如下:
具体部署行为 如下:
具体评估行为 如下:
分两步评估攻击的有效性。
总体实验结果如下表所示,下表列出了知名供应商们的漏洞。大部分知名供应商只需要提供邮箱地址即可变更账户密码,并且会收到一种或多种DNS投毒攻击的影响。例如,在31个测试提供商中,28个(90%)提供商易受FragDNS攻击,4个提供商易受SadDNS攻击。
进一步地,在掌握这些账号后,不同类型资源和不同供应平台账号能够造成的攻击和影响也不尽相同。如下表所示,可能造成资产被永久控制或者流量被劫持。
攻击范围只影响局部网络,而不影响整个互联网,如BGP攻击仅仅短暂地声明一个前缀,所以这种攻击在简单的同时又比较隐蔽,难以被发现。