ID | Name |
---|---|
T1071.001 | Web Protocols |
T1071.002 | File Transfer Protocols |
T1071.003 | Mail Protocols |
T1071.004 | DNS |
Adversaries may communicate using the Domain Name System (DNS) application layer protocol to avoid detection/network filtering by blending in with existing traffic. Commands to the remote system, and often the results of those commands, will be embedded within the protocol traffic between the client and server.
The DNS protocol serves an administrative function in computer networking and thus may be very common in environments. DNS traffic may also be allowed even before network authentication is completed. DNS packets contain many fields and headers in which data can be concealed. Often known as DNS tunneling, adversaries may abuse DNS to communicate with systems under their control within a victim network while also mimicking normal, expected traffic.[1][2]
ID | Name | Description |
---|---|---|
S0504 | Anchor |
Variants of Anchor can use DNS tunneling to communicate with C2.[3][4] |
G0026 | APT18 | |
G0087 | APT39 |
APT39 has used remote access tools that leverage DNS in communications with C2.[6] |
G0096 | APT41 | |
S0360 | BONDUPDATER |
BONDUPDATER can use DNS and TXT records within its DNS tunneling protocol for command and control.[9] |
G0114 | Chimera |
Chimera has used Cobalt Strike to encapsulate C2 in DNS traffic.[10] |
G0080 | Cobalt Group |
Cobalt Group has used DNS tunneling for C2.[11][12][13] |
S0154 | Cobalt Strike |
Cobalt Strike can use a custom command and control protocol that can be encapsulated in DNS. All protocols use their standard assigned ports.[14][15][16] |
S0338 | Cobian RAT |
Cobian RAT uses DNS for C2.[17] |
S0354 | Denis |
Denis has used DNS tunneling for C2 communications.[18][19][20] |
S0377 | Ebury | |
G0046 | FIN7 |
FIN7 has performed C2 using DNS via A, OPT, and TXT records.[22] |
S0477 | Goopy |
Goopy has the ability to communicate with its C2 over DNS.[20] |
S0690 | Green Lambert |
Green Lambert can use DNS for C2 communications.[23][24] |
S0170 | Helminth | |
S0070 | HTTPBrowser |
HTTPBrowser has used DNS for command and control.[26][27] |
S0260 | InvisiMole |
InvisiMole has used a custom implementation of DNS tunneling to embed C2 communications in DNS requests and replies.[28] |
G0004 | Ke3chang | |
G0140 | LazyScripter |
LazyScripter has leveraged dynamic DNS providers for C2 communications.[30] |
S0167 | Matryoshka |
Matryoshka uses DNS for C2.[31][32] |
S0699 | Mythic | |
S0228 | NanHaiShu | |
G0049 | OilRig |
OilRig has used DNS for C2 including the publicly available |
S0124 | Pisloader | |
S0013 | PlugX |
PlugX can be configured to use DNS for command and control.[26] |
S0145 | POWERSOURCE |
POWERSOURCE uses DNS TXT records for C2.[40][41] |
S0184 | POWRUNER | |
S0269 | QUADAGENT | |
S0495 | RDAT | |
S0125 | Remsec | |
S0596 | ShadowPad | |
S0633 | Sliver | |
S0615 | SombRAT |
SombRAT can communicate over DNS with the C2 server.[52][53] |
S0157 | SOUNDBITE | |
S0559 | SUNBURST |
SUNBURST used DNS for C2 traffic designed to mimic normal SolarWinds API communications.[55] |
S0146 | TEXTMATE | |
G0081 | Tropic Trooper |
Tropic Trooper's backdoor has communicated to the C2 over the DNS protocol.[56] |
S0514 | WellMess |
WellMess has the ability to use DNS tunneling for C2 communications.[57][58] |
ID | Mitigation | Description |
---|---|---|
M1037 | Filter Network Traffic |
Consider filtering DNS requests to unknown, untrusted, or known bad domains and resources. Resolving DNS requests with on-premise/proxy servers may also disrupt adversary attempts to conceal data within DNS packets. |
M1031 | Network Intrusion Prevention |
Network intrusion detection and prevention systems that use network signatures to identify traffic for specific adversary malware can be used to mitigate activity at the network level. |
ID | Data Source | Data Component |
---|---|---|
DS0029 | Network Traffic | Network Traffic Content |
Network Traffic Flow |
Analyze network data for uncommon data flows (e.g., a client sending significantly more data than it receives from a server). Processes utilizing the network that do not normally have network communication or have never been seen before are suspicious. Analyze packet contents to detect application layer protocols that do not follow the expected protocol standards regarding syntax, structure, or any other variable adversaries could leverage to conceal data.[59]
Monitor for DNS traffic to/from known-bad or suspicious domains.