APT29针对欧洲外交官的钓鱼攻击活动再度活跃

安全动态   ·   发表于 2025-04-20 20:18:08   ·   安全动态每天看
<p data-lake-id="u21aa56a9" id="u21aa56a9"><span data-lake-id="ucd27bfaa" id="ucd27bfaa" class="lake-fontsize-9" style="color: rgb(10, 10, 10)">​</span><br></p><p data-lake-id="ua1cd3795" id="ua1cd3795" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fresearch.checkpoint.com%2Fwp-content%2Fuploads%2F2025%2F04%2Fwineloader_banner.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A1534%2C%22originHeight%22%3A760%2C%22ratio%22%3A1%2C%22status%22%3A%22done%22%2C%22style%22%3A%22none%22%2C%22showTitle%22%3Afalse%2C%22title%22%3A%22%22%2C%22rotation%22%3A0%2C%22crop%22%3A%5B0%2C0%2C1%2C1%5D%2C%22id%22%3A%22PiL9S%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D"></card></p><h1 data-lake-id="UmXTz" id="UmXTz" style="text-align: center"><span data-lake-id="u57136c64" id="u57136c64" style="color: rgb(63, 63, 63)">APT29针对欧洲外交官的钓鱼攻击活动再度活跃</span></h1><h2 data-lake-id="ZgwiO" id="ZgwiO" style="text-align: center"><span data-lake-id="ue957f4d4" id="ue957f4d4" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">要点概览</span></h2><ul list="uefb7e5ad"><li fid="u374d46b3" data-lake-id="ua7894157" id="ua7894157" style="text-align: left"><span data-lake-id="u6ecef239" id="u6ecef239" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• Check Point Research 一直在追踪由 APT29 发起的一项高级钓鱼攻击活动。APT29 是一个与俄罗斯有关联的威胁组织，当前正在针对欧洲的外交机构展开攻击。</span></li><li fid="u374d46b3" data-lake-id="uc8f5a2be" id="uc8f5a2be" style="text-align: left"><span data-lake-id="u04ce590b" id="u04ce590b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 该活动似乎是此前使用名为</span><span data-lake-id="u5cfc5cfd" id="u5cfc5cfd" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ucbddf72b" id="ucbddf72b" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">WINELOADER</span><span data-lake-id="u37e6501d" id="u37e6501d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u92337331" id="u92337331" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">后门的攻击行动的延续，攻击者伪装成某欧洲主要外交部，向目标发送虚假的外交活动邀请——最常见的是葡萄酒品鉴会邀请。</span></li><li fid="u374d46b3" data-lake-id="u9811e39c" id="u9811e39c" style="text-align: left"><span data-lake-id="u297688d4" id="u297688d4" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 此次活动中使用了一个新的加载器，被称为 GRAPELOADER，通过钓鱼邮件中的链接下载。此外，研究人员还发现了一个可能在攻击后期使用的新版本 WINELOADER。</span></li><li fid="u374d46b3" data-lake-id="u82e5965a" id="u82e5965a" style="text-align: left"><span data-lake-id="uc269523a" id="uc269523a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 虽然改进版的 WINELOADER 仍作为模块化后门在后期使用，但 GRAPELOADER 是攻击初期观察到的新工具，用于指纹识别、持久化和载荷投递。尽管两者功能不同，但在代码结构、混淆方式和字符串解密机制方面具有相似性。GRAPELOADER 在继承 WINELOADER 的反分析技术基础上，引入了更加先进的隐蔽手段。</span></li></ul><card type="block" name="hr" value="data:%7B%22id%22%3A%22QqEZL%22%7D"></card><h2 data-lake-id="hyzQH" id="hyzQH" style="text-align: center"><span data-lake-id="u4a446965" id="u4a446965" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">背景介绍</span></h2><p data-lake-id="ua1aa1d65" id="ua1aa1d65" style="text-align: justify"><span data-lake-id="ubd22884c" id="ubd22884c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">从 2025 年 1 月开始，Check Point Research（CPR）便在追踪一波针对欧洲政府与外交官的定向钓鱼攻击。本次活动中的技术、战术和程序（TTPs）与此前归因于</span><span data-lake-id="u452f8d1c" id="u452f8d1c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uf65a6cc7" id="uf65a6cc7" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">APT29</span><span data-lake-id="uf5b0245c" id="uf5b0245c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u093a0c54" id="u093a0c54" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的 WINELOADER 攻击活动相符。APT29 也被称为 Midnight Blizzard 或 Cozy Bear，是一个专门针对高价值目标的威胁组织，目标包括政府机构和智库。</span></p><p data-lake-id="u85398893" id="u85398893" style="text-align: justify"><span data-lake-id="uf6869e2a" id="uf6869e2a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">APT29 的攻击方式多样，从定向钓鱼攻击到利用自研或商业恶意软件进行的大型供应链攻击。该组织还曾被</span><span data-lake-id="u81c9c059" id="u81c9c059" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u72f1d8b2" id="u72f1d8b2" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">关联</span><span data-lake-id="u824313bf" id="u824313bf" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uf97791c0" id="uf97791c0" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">到 SolarWinds 供应链攻击事件中。</span></p><p data-lake-id="u1808f8cd" id="u1808f8cd" style="text-align: justify"><span data-lake-id="u464d40f3" id="u464d40f3" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">在本轮攻击中，攻击者伪装成某欧洲外交部，向目标发送葡萄酒品鉴会邀请邮件，诱导其点击内嵌链接，从而部署新型后门 GRAPELOADER。此次攻击的目标主要是欧洲的外交机构，也包括一些设于欧洲的非欧洲国家的大使馆。</span></p><p data-lake-id="u2abcfebc" id="u2abcfebc" style="text-align: justify"><span data-lake-id="u1048eab2" id="u1048eab2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">除了 GRAPELOADER 外，研究人员还发现了 WINELOADER 的一个新变种在此次攻击中被使用。其编译时间戳及与 GRAPELOADER 的相似性表明该变种很可能是在攻击后期阶段被投放使用。</span></p><card type="block" name="hr" value="data:%7B%22id%22%3A%22jJLuv%22%7D"></card><h2 data-lake-id="ybjTp" id="ybjTp" style="text-align: center"><span data-lake-id="u179ee266" id="u179ee266" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">攻击活动概述</span></h2><p data-lake-id="u7129dc1f" id="u7129dc1f" style="text-align: justify"><span data-lake-id="u9aa3b59c" id="u9aa3b59c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">大约在 WINELOADER 上一轮攻击活动过去一年后，APT29 又发起了一波新的钓鱼攻击。他们伪装成某欧洲外交部的名义，发送葡萄酒品鉴会的邀请邮件。邮件中包含一个恶意链接，部分情况下该链接会下载一个压缩包文件，最终导致 GRAPELOADER 的部署；而在另一些情况下，该链接会将收件人重定向到该外交部的官方网站。</span></p><p data-lake-id="u40a17f9f" id="u40a17f9f" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fresearch.checkpoint.com%2Fwp-content%2Fuploads%2F2025%2F04%2Fgrapeloader_infection.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A2788%2C%22originHeight%22%3A936%2C%22ratio%22%3A1%2C%22status%22%3A%22done%22%2C%22style%22%3A%22none%22%2C%22showTitle%22%3Afalse%2C%22title%22%3A%22%22%2C%22rotation%22%3A0%2C%22crop%22%3A%5B0%2C0%2C1%2C1%5D%2C%22id%22%3A%22pO9cG%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D"></card></p><p data-lake-id="ud81bff62" id="ud81bff62" style="text-align: justify"><span data-lake-id="ub3c15d7a" id="ub3c15d7a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Figure 1 – High-level overview of GRAPELOADER infections.</span></p><p data-lake-id="u681c93d0" id="u681c93d0" style="text-align: justify"><span data-lake-id="u082933d1" id="u082933d1" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">在整个攻击活动中，目标涵盖多个欧洲国家，重点针对各国外交部以及驻欧洲的其他国家使馆。除了我们识别出的钓鱼邮件之外，还有迹象表明，APT29 也在有限范围内对欧洲以外的目标进行了攻击，包括驻中东的外交官。</span></p><h3 data-lake-id="A9BDz" id="A9BDz" style="text-align: left"><span data-lake-id="u4e84e8a8" id="u4e84e8a8" style="color: rgb(63, 63, 63)">钓鱼邮件</span></h3><p data-lake-id="u8568c13c" id="u8568c13c" style="text-align: justify"><span data-lake-id="u8b5eed06" id="u8b5eed06" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">这些被识别出的钓鱼邮件至少来自两个不同的域名：</span><span data-lake-id="u782cdae3" id="u782cdae3" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">bakenhof[.]com</span><span data-lake-id="u52a7301d" id="u52a7301d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ue7824251" id="ue7824251" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">和</span><span data-lake-id="uf01fe7f3" id="uf01fe7f3" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ud39b2f5e" id="ud39b2f5e" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">silry[.]com</span><span data-lake-id="u2b5e5db5" id="u2b5e5db5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，发件人地址伪装成某欧洲外交部的特定人员。每封邮件都包含一个恶意链接，点击后会下载名为</span><span data-lake-id="u0cf7811e" id="u0cf7811e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uaa17e108" id="uaa17e108" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">wine.zip</span><span data-lake-id="u88ac130b" id="u88ac130b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u0ee2ed13" id="u0ee2ed13" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的文件，进入攻击的下一阶段。承载该链接的域名与发送邮件的域名相同。</span></p><p data-lake-id="u35e0c4e6" id="u35e0c4e6" style="text-align: justify"><span data-lake-id="u9ec48d28" id="u9ec48d28" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">当最初的攻击尝试失败时，攻击者会发送多轮钓鱼邮件，以提高目标点击链接、从而感染设备的可能性。</span></p><p data-lake-id="ua54b3a7e" id="ua54b3a7e" style="text-align: justify"><span data-lake-id="u6d3c7140" id="u6d3c7140" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">我们识别出该活动中发送的多封钓鱼邮件，几乎全部都以“葡萄酒品鉴会”活动为主题：</span></p><table data-lake-id="t7vN6" id="t7vN6" margin="true" class="lake-table" style="width: 750px"><colgroup><col width="750"></colgroup><tbody><tr data-lake-id="u687bad8e" id="u687bad8e"><td data-lake-id="ub54f496b" id="ub54f496b"><p data-lake-id="u807929af" id="u807929af" style="text-align: left"><span data-lake-id="ue6dbf1f9" id="ue6dbf1f9" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Email subjects</span></p></td></tr><tr data-lake-id="ueca794b0" id="ueca794b0"><td data-lake-id="uab54f3c0" id="uab54f3c0"><p data-lake-id="ub04c5ea0" id="ub04c5ea0" style="text-align: left"><span data-lake-id="u37d364ec" id="u37d364ec" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Wine Event</span></p></td></tr><tr data-lake-id="u0ed91d07" id="u0ed91d07"><td data-lake-id="u8145ff78" id="u8145ff78"><p data-lake-id="u43bd0078" id="u43bd0078" style="text-align: left"><span data-lake-id="u927fa946" id="u927fa946" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Wine Testing Event</span></p></td></tr><tr data-lake-id="u52f82d80" id="u52f82d80"><td data-lake-id="ue217033f" id="ue217033f"><p data-lake-id="uda29937e" id="uda29937e" style="text-align: left"><span data-lake-id="uc7752bd3" id="uc7752bd3" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Wine tasting event (update date)</span></p></td></tr><tr data-lake-id="u8b2d6ba5" id="u8b2d6ba5"><td data-lake-id="u7e2027d3" id="u7e2027d3"><p data-lake-id="u8e689b05" id="u8e689b05" style="text-align: left"><span data-lake-id="u194440a5" id="u194440a5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">For Ambassador’s Calendar</span></p></td></tr><tr data-lake-id="u70504f1d" id="u70504f1d"><td data-lake-id="u9e0144d1" id="u9e0144d1"><p data-lake-id="ua3bc7c46" id="ua3bc7c46" style="text-align: left"><span data-lake-id="ua43d567c" id="ua43d567c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Diplomatic dinner</span></p></td></tr></tbody></table><ul list="u0f0e8385"><li fid="u120a44fb" data-lake-id="u213ba0de" id="u213ba0de" style="text-align: left"><span data-lake-id="u6518a9c8" id="u6518a9c8" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 服务器所托管的链接被认为具备较高的防扫描和反自动化分析能力，只有在满足特定条件（如特定时间段或地理位置）时才会触发恶意下载行为。当直接访问该链接时，会被重定向至被伪装的外交部官方网站。</span></li></ul><h3 data-lake-id="mSzUS" id="mSzUS" style="text-align: left"><span data-lake-id="u04f336f4" id="u04f336f4" style="color: rgb(63, 63, 63)">GRAPELOADER 感染过程</span></h3><ul list="u0f0e8385" start="2"><li fid="u120a44fb" data-lake-id="u4d4a2949" id="u4d4a2949" style="text-align: left"><span data-lake-id="u8ce68ddd" id="u8ce68ddd" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">wine.zip</span><span data-lake-id="u331227c7" id="u331227c7" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ub918525f" id="ub918525f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">压缩包中包含三个文件：</span></li></ul><p data-lake-id="u2387389a" id="u2387389a" style="text-align: justify"><span data-lake-id="ub8c8c61c" id="ub8c8c61c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">当</span><span data-lake-id="u3d95118c" id="u3d95118c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ucd4f90d0" id="ucd4f90d0" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">wine.exe</span><span data-lake-id="u5fad121a" id="u5fad121a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uf3e90597" id="uf3e90597" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">被执行并成功旁加载 GRAPELOADER 后，恶意程序会将</span><span data-lake-id="u247ab27a" id="u247ab27a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u4b7c357d" id="u4b7c357d" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">wine.zip</span><span data-lake-id="u67172021" id="u67172021" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u3c233e48" id="u3c233e48" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的内容复制到磁盘上的新位置。接着，它会通过修改 Windows 注册表中的 Run 键来实现持久化，确保每次系统重启时</span><span data-lake-id="u49a18a0f" id="u49a18a0f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ub622b830" id="ub622b830" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">wine.exe</span><span data-lake-id="u51947b80" id="u51947b80" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ucc360eb4" id="ucc360eb4" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">都会自动运行。</span></p><p data-lake-id="ub97926d7" id="ub97926d7" style="text-align: justify"><span data-lake-id="u7574da31" id="u7574da31" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">之后，GRAPELOADER 会收集被感染主机的基本信息（如主机名和用户名），并将这些数据发送至 C2（命令与控制）服务器，然后等待下一阶段的 shellcode（恶意代码）下发。</span></p><h3 data-lake-id="L31mb" id="L31mb" style="text-align: left"><span data-lake-id="ua4d14602" id="ua4d14602" style="color: rgb(63, 63, 63)">新版 WINELOADER</span></h3><p data-lake-id="u42fa7e84" id="u42fa7e84" style="text-align: justify"><span data-lake-id="uc627c7e0" id="uc627c7e0" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">除了 GRAPELOADER 相关钓鱼邮件外，研究人员还在 VirusTotal 上发现了一个新的 WINELOADER 变种。该变种与</span><span data-lake-id="u3d97a9f5" id="u3d97a9f5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u63f08618" id="u63f08618" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">AppvIsvSubsystems64.dll</span><span data-lake-id="uc93efed7" id="uc93efed7" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uc076529a" id="uc076529a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">拥有相同的 Rich-PE 头部信息以及接近的编译时间戳，说明两者可能属于同一攻击流程的一部分。结合我们发现的信息，以及 GRAPELOADER 替代了之前用于下载 WINELOADER 的 HTA 下载器 ROOTSAW，我们认为 GRAPELOADER 最终的目标仍是部署 WINELOADER。</span></p><h2 data-lake-id="GVrVT" id="GVrVT" style="text-align: center"><span data-lake-id="u5115277d" id="u5115277d" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">技术分析</span></h2><p data-lake-id="u30c60be8" id="u30c60be8" style="text-align: justify"><strong><span data-lake-id="uf2a1dfbf" id="uf2a1dfbf" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">WINELOADER</span></strong><span data-lake-id="u9ea0293b" id="u9ea0293b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ubb7efb29" id="ubb7efb29" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">是一个</span><span data-lake-id="u5888d150" id="u5888d150" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u0fe63605" id="u0fe63605" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">知名的模块化远控后门</span><span data-lake-id="u55150f9d" id="u55150f9d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，属于 APT29 的工具之一；而</span><span data-lake-id="u2f42eaac" id="u2f42eaac" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="ubdf6a624" id="ubdf6a624" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">GRAPELOADER</span></strong><span data-lake-id="u09318c10" id="u09318c10" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ufd23f8bd" id="ufd23f8bd" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">是近期首次观测到的工具，用于攻击链的初始阶段，主要任务包括环境指纹识别、持久化建立以及下一阶段载荷的下载。尽管两者在功能上不同，但深入分析发现，新版 WINELOADER 与 GRAPELOADER 在代码结构、混淆方式和字符串解密处理上存在诸多相似之处。</span></p><p data-lake-id="u899f2d7f" id="u899f2d7f" style="text-align: justify"><span data-lake-id="u4d3b628f" id="u4d3b628f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">对旧版与新版 WINELOADER 的对比显示，该后门不断演化，在保留核心功能的同时，还进一步优化了原有技术。GRAPELOADER 不仅继承并强化了某些先进技术（如 DLL 解除挂钩、API 动态解析、代码混淆和字符串加密），还引入了全新的隐蔽手段，以提高整体的隐匿性与攻击效率。</span></p><h3 data-lake-id="tV1Ju" id="tV1Ju" style="text-align: left"><span data-lake-id="u84dfe212" id="u84dfe212" style="color: rgb(63, 63, 63)">GRAPELOADER 详情</span></h3><p data-lake-id="ube374ba2" id="ube374ba2" style="text-align: justify"><span data-lake-id="ub58b91f9" id="ub58b91f9" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">GRAPELOADER 以一个 64 位 DLL (</span><span data-lake-id="u43337602" id="u43337602" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">ppcore.dll</span><span data-lake-id="u2253461e" id="u2253461e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">) 的形式交付，导出了两个函数：</span><span data-lake-id="u3ac49ae4" id="u3ac49ae4" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">PPMain</span><span data-lake-id="u982f8905" id="u982f8905" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uf9ecc460" id="uf9ecc460" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">和</span><span data-lake-id="u590c4382" id="u590c4382" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u2278e12d" id="u2278e12d" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">DllGetLCID</span><span data-lake-id="u7f9c0a28" id="u7f9c0a28" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。其中</span><span data-lake-id="u7f4e6d59" id="u7f4e6d59" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ufd573912" id="ufd573912" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">DllGetLCID</span><span data-lake-id="u51b0cf73" id="u51b0cf73" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uc3994431" id="uc3994431" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">仅包含经过变异的垃圾代码（即通过大循环进行复杂数学运算的有效指令），主要用于代码膨胀。类似技术也被应用于</span><span data-lake-id="u77738c27" id="u77738c27" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ub256f97c" id="ub256f97c" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">AppvIsvSubsystems64.dll</span><span data-lake-id="u85026676" id="u85026676" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，它作为</span><span data-lake-id="udd1610d1" id="udd1610d1" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ud2f5272a" id="ud2f5272a" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">wine.exe</span><span data-lake-id="u6f33e6cf" id="u6f33e6cf" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u92ff00f3" id="u92ff00f3" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">正常运行所需的依赖项。</span><span data-lake-id="u8ed071b1" id="u8ed071b1" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">PPMain</span><span data-lake-id="u9503450f" id="u9503450f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u9522ca15" id="u9522ca15" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">则是实际触发恶意逻辑的函数。</span></p><p data-lake-id="ua4593877" id="ua4593877" style="text-align: justify"><span data-lake-id="u60467262" id="u60467262" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">该 DLL 是通过</span><span data-lake-id="u8d4fb8b5" id="u8d4fb8b5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u9ae8344e" id="u9ae8344e" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">DLL 旁加载</span></strong><span data-lake-id="ued7d030e" id="ued7d030e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ub33a7089" id="ub33a7089" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">和</span><span data-lake-id="ubba3f04c" id="ubba3f04c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uc3fbb895" id="uc3fbb895" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">wine.exe</span><span data-lake-id="u09c2b9f5" id="u09c2b9f5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u7acc72af" id="u7acc72af" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的</span><span data-lake-id="u85fabf6e" id="u85fabf6e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u285ec8f0" id="u285ec8f0" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">延迟导入（Delayed Imports）</span></strong><span data-lake-id="u23229073" id="u23229073" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ud81f8338" id="ud81f8338" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">来执行的，作为初始阶段的下载器运行。由于其是通过导出的</span><span data-lake-id="uefb2651b" id="uefb2651b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ufccc7e89" id="ufccc7e89" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">PPMain</span><span data-lake-id="u9876e6a8" id="u9876e6a8" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u6ddbdde4" id="u6ddbdde4" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">函数执行而非</span><span data-lake-id="u0c752656" id="u0c752656" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u9849eb4f" id="u9849eb4f" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">DllEntryPoint</span><span data-lake-id="u26417d67" id="u26417d67" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，因此不受 Loader Lock 限制。</span></p><p data-lake-id="u013ea77a" id="u013ea77a" style="text-align: justify"><strong><span data-lake-id="ub139868b" id="ub139868b" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">反分析技术</span></strong></p><p data-lake-id="u842238fa" id="u842238fa" style="text-align: justify"><span data-lake-id="u82224f16" id="u82224f16" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">GRAPELOADER 在其代码中运用了多种反分析技术，包括：</span></p><p data-lake-id="ua58e7727" id="ua58e7727" style="text-align: justify"><strong><span data-lake-id="ud1acfb14" id="ud1acfb14" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">字符串混淆</span></strong><span data-lake-id="udfaa7bd1" id="udfaa7bd1" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">：每个字符串都通过三步处理流程：</span></p><p data-lake-id="u32f21e7d" id="u32f21e7d" style="text-align: justify"><span data-lake-id="u5bfa140a" id="u5bfa140a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">此方法有效规避了常见的自动字符串提取与解混淆工具，如</span><span data-lake-id="u42aaf146" id="u42aaf146" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ued67cdd2" id="ued67cdd2" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">FLOSS</span><span data-lake-id="u631e606a" id="u631e606a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，因为解密后的字符串不会在内存中长期存在。此外，每个字符串都有独立的处理逻辑，使得基于特征的检测工具难以可靠识别和提取。</span></p><p data-lake-id="uf86ca830" id="uf86ca830" style="text-align: justify"><strong><span data-lake-id="uf4462947" id="uf4462947" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">运行时 API 解析与 DLL 解除挂钩（unhooking）</span></strong><span data-lake-id="u82695bf9" id="u82695bf9" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">：在调用任何</span><span data-lake-id="u6c620567" id="u6c620567" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u5237faa3" id="u5237faa3" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">WIN API</span></strong><span data-lake-id="u9cba2317" id="u9cba2317" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u1996f2f4" id="u1996f2f4" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">或</span><span data-lake-id="u6eb2a7d8" id="u6eb2a7d8" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="ufbc76a26" id="ufbc76a26" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">NT API</span></strong><span data-lake-id="u791cc51d" id="u791cc51d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ua04dcdd9" id="ua04dcdd9" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">函数之前，GRAPELOADER 会先解除目标 DLL 的挂钩，然后通过内存中对 PE 文件的解析，动态解析 API 地址。</span></p><ol list="u58955e9a" data-lake-indent="1"><li fid="u91f47a12" data-lake-id="u8103c96c" id="u8103c96c" style="text-align: left"><span data-lake-id="u0efa9e79" id="u0efa9e79" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">1. 提取加密字节块；</span></li><li fid="u91f47a12" data-lake-id="u6459b3ce" id="u6459b3ce" style="text-align: left"><span data-lake-id="uf6d465fd" id="uf6d465fd" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">2. 通过自定义算法进行解密；</span></li><li fid="u91f47a12" data-lake-id="u7cb1bb0e" id="u7cb1bb0e" style="text-align: left"><span data-lake-id="u8bed8b54" id="u8bed8b54" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">3. 在使用后立即将内存中的解密数据清零。</span></li></ol><ul list="u5660cf18" data-lake-indent="1"><li fid="u0a9c6de8" data-lake-id="u5d5bc8a9" id="u5d5bc8a9" style="text-align: left"><span data-lake-id="u97f5ba7f" id="u97f5ba7f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 一个合法的 PowerPoint 可执行文件</span><span data-lake-id="uce4bd49d" id="uce4bd49d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u9f69fda9" id="u9f69fda9" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">wine.exe</span><span data-lake-id="u31b3d920" id="u31b3d920" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，被用于 DLL 旁加载（DLL Side-loading）攻击。</span></li><li fid="u0a9c6de8" data-lake-id="ude2239f6" id="ude2239f6" style="text-align: left"><span data-lake-id="u7153550a" id="u7153550a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 一个隐藏的 DLL 文件</span><span data-lake-id="u8a9ca203" id="u8a9ca203" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ud139e964" id="ud139e964" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">AppvIsvSubsystems64.dll</span><span data-lake-id="u43068d50" id="u43068d50" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，其中填充了大量无用代码，仅作为 PowerPoint 可执行程序运行所需的依赖项。</span></li><li fid="u0a9c6de8" data-lake-id="uaf1f5a8f" id="uaf1f5a8f" style="text-align: left"><span data-lake-id="uf34b9a7c" id="uf34b9a7c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 另一个隐藏且高度混淆的 DLL 文件</span><span data-lake-id="u1f0b96ef" id="u1f0b96ef" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u1e014824" id="u1e014824" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">ppcore.dll</span><span data-lake-id="ua658d7f8" id="ua658d7f8" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，作为加载器运行，被称为</span><span data-lake-id="u5acb4f6c" id="u5acb4f6c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u1a07c268" id="u1a07c268" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">GRAPELOADER</span></strong><span data-lake-id="u1af77802" id="u1af77802" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，它可能在后续阶段用于加载 WINELOADER。</span></li></ul><p data-lake-id="u0e4385dc" id="u0e4385dc" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fresearch.checkpoint.com%2Fwp-content%2Fuploads%2F2025%2F04%2FLX79FK4NVZ-image2.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A964%2C%22originHeight%22%3A558%2C%22ratio%22%3A1%2C%22status%22%3A%22done%22%2C%22style%22%3A%22none%22%2C%22showTitle%22%3Afalse%2C%22title%22%3A%22%22%2C%22rotation%22%3A0%2C%22crop%22%3A%5B0%2C0%2C1%2C1%5D%2C%22id%22%3A%22TNReW%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D"></card></p><p data-lake-id="ued609ae3" id="ued609ae3" style="text-align: justify"><span data-lake-id="udcfe285d" id="udcfe285d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Figure 2 – GRAPELOADER – API resolving &amp; DLL unhooking.</span></p><p data-lake-id="u2e9149aa" id="u2e9149aa" style="text-align: justify"><span data-lake-id="u425089b8" id="u425089b8" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">*</span><em><strong><span data-lake-id="uf452f4a8" id="uf452f4a8" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">持久化机制*</span></strong></em></p><p data-lake-id="u96c7d0a6" id="u96c7d0a6" style="text-align: justify"><span data-lake-id="ub0200ef2" id="ub0200ef2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">恶意程序的执行从设置</span><strong><span data-lake-id="u2bcd7b8e" id="u2bcd7b8e" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">持久化</span></strong><span data-lake-id="udf594b4f" id="udf594b4f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">开始，但前提是当前进程的</span><strong><span data-lake-id="u4b400dcb" id="u4b400dcb" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">工作目录</span></strong><span data-lake-id="uf785d0e9" id="uf785d0e9" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">不是</span><span data-lake-id="ub2d99758" id="ub2d99758" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u43309b4e" id="u43309b4e" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">C:\Windows\System32</span><span data-lake-id="ubf4ec6d5" id="ubf4ec6d5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。这一检查用于防止在通过</span><span data-lake-id="u28698357" id="u28698357" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ucf09b9e0" id="ucf09b9e0" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">rundll32.exe</span><span data-lake-id="uca06371d" id="uca06371d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u891ab24c" id="u891ab24c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">等工具执行时建立持久化（尽管恶意程序仍会执行）。如果满足建立持久化的条件，GRAPELOADER 将执行以下操作：</span></p><ol list="ufb7231e2"><li fid="u2ed1231c" data-lake-id="u950c7f0f" id="u950c7f0f" style="text-align: left"><span data-lake-id="uc6088df2" id="uc6088df2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">1. 将传递的压缩包</span><span data-lake-id="uae61f1e0" id="uae61f1e0" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u7426f6de" id="u7426f6de" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">wine (2).zip</span><span data-lake-id="ucea4a02a" id="ucea4a02a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u705cc661" id="u705cc661" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的内容复制到目录</span><span data-lake-id="ub9703221" id="ub9703221" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uf60c7bd9" id="uf60c7bd9" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">C:\Users\User\AppData\Local\POWERPNT\</span><span data-lake-id="ub8c38059" id="ub8c38059" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。</span></li><li fid="u2ed1231c" data-lake-id="u03577a23" id="u03577a23" style="text-align: left"><span data-lake-id="u1a21e7ce" id="u1a21e7ce" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">2. 在注册表路径</span><span data-lake-id="u53c9721a" id="u53c9721a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ued9683c7" id="ued9683c7" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">SOFTWARE\Microsoft\Windows\CurrentVersion\Run</span><span data-lake-id="ubae845e5" id="ubae845e5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ud64d5ae1" id="ud64d5ae1" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">下创建一个名为</span><span data-lake-id="u859c9262" id="u859c9262" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u554327f5" id="u554327f5" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">POWERPNT</span><span data-lake-id="u3486d4bf" id="u3486d4bf" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u395429dc" id="u395429dc" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的</span><strong><span data-lake-id="u73e8fd2c" id="u73e8fd2c" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">Run项</span></strong><span data-lake-id="u4705186a" id="u4705186a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，指向</span><span data-lake-id="u16c021f5" id="u16c021f5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u15dc3ae1" id="u15dc3ae1" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">C:\Users\User\AppData\Local\POWERPNT\wine.exe</span><span data-lake-id="u2132ac4d" id="u2132ac4d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。</span></li></ol><p data-lake-id="u61d65f87" id="u61d65f87" style="text-align: justify"><strong><span data-lake-id="u9025634b" id="u9025634b" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">C2 通信</span></strong></p><p data-lake-id="u608cc061" id="u608cc061" style="text-align: justify"><span data-lake-id="u90af1d61" id="u90af1d61" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">在建立持久化之后，恶意代码进入一个无限循环，每</span><strong><span data-lake-id="u564d704a" id="u564d704a" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">60秒</span></strong><span data-lake-id="u34d6ccba" id="u34d6ccba" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">轮询一次其</span><strong><span data-lake-id="ud5f759af" id="ud5f759af" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">C2服务器</span></strong><span data-lake-id="u6561bb46" id="u6561bb46" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。最初，它会收集目标环境的基本信息，包括：</span><span data-lake-id="u48f7dea4" id="u48f7dea4" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">UserName</span><span data-lake-id="uf6872706" id="uf6872706" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">、</span><span data-lake-id="ufaf3599a" id="ufaf3599a" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">ComputerName</span><span data-lake-id="u9f534989" id="u9f534989" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">、</span><span data-lake-id="uc3c27153" id="uc3c27153" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">ProcessName</span><span data-lake-id="ua0d5faf3" id="ua0d5faf3" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uf078d420" id="uf078d420" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">和</span><span data-lake-id="u7f737ae9" id="u7f737ae9" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u15a0782d" id="u15a0782d" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">ProcessPID</span><span data-lake-id="u2198d46f" id="u2198d46f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。<br /></span><span data-lake-id="u771e4f5f" id="u771e4f5f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">这些信息连同一个</span><strong><span data-lake-id="ufabd7672" id="ufabd7672" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">硬编码的64位十六进制字符串</span></strong><span data-lake-id="u2c90fbb2" id="u2c90fbb2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u2a003da9" id="u2a003da9" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">e55c854d77279ed516579b91315783edd776ac0ff81ea4cc5b2b0811cf40aa63</span><span data-lake-id="u5f6ef6df" id="u5f6ef6df" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">（被认为是用于标识活动或版本的标签）一同构造成如下格式的数据结构：</span></p><card type="inline" name="codeblock" value="data:%7B%22search%22%3A%22%22%2C%22mode%22%3A%22plain%22%2C%22code%22%3A%22struct%20CollectedEnvironmentInfo%5Cn%7B%5Cn%20%20%20%20BYTE%20UserName%5B512%5D%3B%5Cn%20%20%20%20BYTE%20ComputerName%5B512%5D%3B%5Cn%20%20%20%20BYTE%20ProcessName%5B512%5D%3B%5Cn%20%20%20%20DWORD%20ProcessPID%3B%5Cn%20%20%20%20BYTE%20HardcodedHexString%5B64%5D%3B%5Cn%20%20%20%20DWORD%20GenRandNumFromSystemTime%3B%5Cn%7D%3B%22%2C%22autoWrap%22%3Afalse%2C%22lineNumbers%22%3Atrue%2C%22heightLimit%22%3Atrue%2C%22collapsed%22%3Afalse%2C%22hideToolbar%22%3Afalse%2C%22name%22%3A%22%22%2C%22tabSize%22%3Anull%2C%22indentWithTab%22%3Afalse%2C%22lightLines%22%3A%5B%5D%2C%22foldLines%22%3A%5B%5D%2C%22customStyle%22%3A%5B%5D%2C%22theme%22%3A%22Github%20Light%22%2C%22__spacing%22%3A%22both%22%2C%22id%22%3A%22slGDZ%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D"></card><p data-lake-id="ua34ba091" id="ua34ba091" style="text-align: justify"><span data-lake-id="u350f7e96" id="u350f7e96" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">该数据结构通过</span><span data-lake-id="u8526c852" id="u8526c852" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="ua73e45bb" id="ua73e45bb" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">HTTPS POST</span></strong><span data-lake-id="u8fefcd14" id="u8fefcd14" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u3bd9e092" id="u3bd9e092" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">请求发送至 C2 服务器</span><span data-lake-id="ud4741a80" id="ud4741a80" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u4eac81fb" id="u4eac81fb" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">https[:]//ophibre[.]com/blog.php</span><span data-lake-id="u744a9810" id="u744a9810" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，并使用如下的</span><span data-lake-id="u1af92a21" id="u1af92a21" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u7b43aac0" id="u7b43aac0" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">User-Agent</span></strong><span data-lake-id="udd97e32c" id="udd97e32c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u361b4d2d" id="u361b4d2d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">字符串：<br /></span><span data-lake-id="u3e695035" id="u3e695035" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/132.0.0.0 Safari/537.36</span><span data-lake-id="u33d554ea" id="u33d554ea" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。</span></p><p data-lake-id="ue7674768" id="ue7674768" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fresearch.checkpoint.com%2Fwp-content%2Fuploads%2F2025%2F04%2FLX79FK4NVZ-image3.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A1797%2C%22originHeight%22%3A795%2C%22ratio%22%3A1%2C%22status%22%3A%22done%22%2C%22style%22%3A%22none%22%2C%22showTitle%22%3Afalse%2C%22title%22%3A%22%22%2C%22rotation%22%3A0%2C%22crop%22%3A%5B0%2C0%2C1%2C1%5D%2C%22id%22%3A%22RZf1o%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D"></card></p><p data-lake-id="udf3f1d13" id="udf3f1d13" style="text-align: justify"><span data-lake-id="u9f6e1b7f" id="u9f6e1b7f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Figure 3 – GRAPELOADER – C2 communication.</span></p><p data-lake-id="ue2ebff7c" id="ue2ebff7c" style="text-align: justify"><strong><span data-lake-id="u98a08036" id="u98a08036" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">Shellcode 执行与规避技术</span></strong></p><p data-lake-id="u077f81a2" id="u077f81a2" style="text-align: justify"><span data-lake-id="u78b56577" id="u78b56577" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">只有在从 C2 服务器接收到数据后，GRAPELOADER 才会继续后续的执行流程。预期的有效载荷是</span><strong><span data-lake-id="u89ab4b05" id="u89ab4b05" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">未加密的</span></strong><span data-lake-id="u879b2953" id="u879b2953" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">、</span><strong><span data-lake-id="u9ec3a388" id="u9ec3a388" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">独立于内存的 shellcode</span></strong><span data-lake-id="u0b180790" id="u0b180790" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，其将在内存中直接执行，</span><strong><span data-lake-id="u5a53fcf0" id="u5a53fcf0" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">不会被写入磁盘</span></strong><span data-lake-id="u06f2b67e" id="u06f2b67e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。</span></p><p data-lake-id="u82c5b90f" id="u82c5b90f" style="text-align: justify"><span data-lake-id="uc8059905" id="uc8059905" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">为了规避 AV/EDR 解决方案的</span><strong><span data-lake-id="uf0d7cde4" id="uf0d7cde4" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">内存扫描</span></strong><span data-lake-id="ufad1d748" id="ufad1d748" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，GRAPELOADER 实现了一种</span><span data-lake-id="u9201a15e" id="u9201a15e" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">众所周知的技术</span><span data-lake-id="ueab7109c" id="ueab7109c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">：</span></p><ol list="ue9206471"><li fid="u39b126d6" data-lake-id="u22c7187b" id="u22c7187b" style="text-align: left"><span data-lake-id="uab753dd7" id="uab753dd7" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">1. 接收到的</span><span data-lake-id="ud6bc4f8f" id="ud6bc4f8f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u22ac8036" id="u22ac8036" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">shellcode</span></strong><span data-lake-id="u46592ad8" id="u46592ad8" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u7c538406" id="u7c538406" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">被复制到一个具备</span><span data-lake-id="uf949dd1b" id="uf949dd1b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ufd7717c6" id="ufd7717c6" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">PAGE_READWRITE</span><span data-lake-id="ud1470877" id="ud1470877" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u25584f4d" id="u25584f4d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">权限的分配内存区域中。</span></li><li fid="u39b126d6" data-lake-id="u6aadd67b" id="u6aadd67b" style="text-align: left"><span data-lake-id="ud34beeba" id="ud34beeba" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">2. 通过</span><span data-lake-id="u38f1e9bb" id="u38f1e9bb" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="uff4eb421" id="uff4eb421" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">NT API</span></strong><span data-lake-id="u9fd44a86" id="u9fd44a86" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ud365ed49" id="ud365ed49" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">NtProtectVirtualMemory</span><span data-lake-id="u018ced28" id="u018ced28" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u245d4e68" id="u245d4e68" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">将该内存区域的</span><strong><span data-lake-id="u7f24a431" id="u7f24a431" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">访问权限</span></strong><span data-lake-id="ue9f815df" id="ue9f815df" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">更改为</span><span data-lake-id="u4fac2a2f" id="u4fac2a2f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u2bb86f5a" id="u2bb86f5a" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">PAGE_NOACCESS</span><span data-lake-id="u047206fb" id="u047206fb" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。</span></li><li fid="u39b126d6" data-lake-id="uea37cdd3" id="uea37cdd3" style="text-align: left"><span data-lake-id="uccb741d8" id="uccb741d8" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">3. 调用</span><span data-lake-id="uf983cabf" id="uf983cabf" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u920593cc" id="u920593cc" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">CreateThread</span><span data-lake-id="uc8812ef2" id="uc8812ef2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u17a975fc" id="u17a975fc" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">Windows API</span></strong><span data-lake-id="ua8fc8b0a" id="ua8fc8b0a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ua310723d" id="ua310723d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">创建一个新的</span><strong><span data-lake-id="u46a6fa1b" id="u46a6fa1b" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">挂起状态线程</span></strong><span data-lake-id="udbb1047a" id="udbb1047a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，其</span><span data-lake-id="ufeed93bb" id="ufeed93bb" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u7780b2bd" id="u7780b2bd" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">lpStartAddress</span><span data-lake-id="u828e1f20" id="u828e1f20" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u1920803a" id="u1920803a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">指向该不可访问的内存区域起始地址。</span></li><li fid="u39b126d6" data-lake-id="ubc585e6a" id="ubc585e6a" style="text-align: left"><span data-lake-id="u56d6757c" id="u56d6757c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">4. 调用</span><span data-lake-id="u8122e827" id="u8122e827" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uc6834292" id="uc6834292" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">Sleep</span><span data-lake-id="u7a067941" id="u7a067941" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="ub623989c" id="ub623989c" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">Windows API</span></strong><span data-lake-id="u8abc39c2" id="u8abc39c2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">（持续 10 秒），为 AV/EDR 提供扫描该不可访问内存区域的时间。</span></li><li fid="u39b126d6" data-lake-id="u6c51efdb" id="u6c51efdb" style="text-align: left"><span data-lake-id="u726d6d79" id="u726d6d79" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">5. 再次使用</span><span data-lake-id="u664b5a1d" id="u664b5a1d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u75d31d54" id="u75d31d54" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">NtProtectVirtualMemory</span><span data-lake-id="u233ac6e5" id="u233ac6e5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uabe29090" id="uabe29090" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">将内存权限更改为</span><span data-lake-id="uca3e987a" id="uca3e987a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u7a42ce5b" id="u7a42ce5b" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">PAGE_EXECUTE_READWRITE</span><span data-lake-id="u5f169924" id="u5f169924" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。</span></li><li fid="u39b126d6" data-lake-id="uf5f1ccf1" id="uf5f1ccf1" style="text-align: left"><span data-lake-id="uae97f1d6" id="uae97f1d6" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">6. 调用</span><span data-lake-id="ua5801d3c" id="ua5801d3c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u51fe06d1" id="u51fe06d1" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">ResumeThread</span><span data-lake-id="ua70b9372" id="ua70b9372" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="ue9f1fc3c" id="ue9f1fc3c" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">Windows API</span></strong><span data-lake-id="uf5b2f968" id="uf5b2f968" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，开始执行 shellcode。</span></li></ol><p data-lake-id="uc6c67f94" id="uc6c67f94" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fresearch.checkpoint.com%2Fwp-content%2Fuploads%2F2025%2F04%2FLX79FK4NVZ-image4.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A1262%2C%22originHeight%22%3A775%2C%22ratio%22%3A1%2C%22status%22%3A%22done%22%2C%22style%22%3A%22none%22%2C%22showTitle%22%3Afalse%2C%22title%22%3A%22%22%2C%22rotation%22%3A0%2C%22crop%22%3A%5B0%2C0%2C1%2C1%5D%2C%22id%22%3A%22krJ8G%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D"></card></p><p data-lake-id="ue43b4ee9" id="ue43b4ee9" style="text-align: justify"><span data-lake-id="u018e2c22" id="u018e2c22" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Figure 4 – GRAPELOADER – Shellcode execution and evasion technique.</span></p><p data-lake-id="ud6b60979" id="ud6b60979" style="text-align: justify"><span data-lake-id="udf819d59" id="udf819d59" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">由于该攻击活动</span><strong><span data-lake-id="u837d9ade" id="u837d9ade" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">具有高度针对性</span></strong><span data-lake-id="u8374cff8" id="u8374cff8" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，通过</span><span data-lake-id="u6e3d295e" id="u6e3d295e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ua1d4a62e" id="ua1d4a62e" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">CollectedEnvironmentInfo</span><span data-lake-id="uac6cc00f" id="uac6cc00f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="udf64e256" id="udf64e256" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">对受感染设备进行指纹识别，并且下一阶段有效载荷的执行</span><strong><span data-lake-id="u7aa893f2" id="u7aa893f2" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">不会留下任何持久化痕迹</span></strong><span data-lake-id="uace31913" id="uace31913" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，因此我们无法获取下一阶段的 shellcode。</span></p><h3 data-lake-id="yI2Re" id="yI2Re" style="text-align: left"><span data-lake-id="u918361a7" id="u918361a7" style="color: rgb(63, 63, 63)">WINELOADER</span></h3><p data-lake-id="uaa8c580a" id="uaa8c580a" style="text-align: justify"><span data-lake-id="u1996a39b" id="u1996a39b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">新的 WINELOADER 变种（</span><span data-lake-id="ub3f4ae0f" id="ub3f4ae0f" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">vmtools.dll</span><span data-lake-id="u918df64d" id="u918df64d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">）是一个 64 位的木马化 DLL，具有</span><span data-lake-id="ue3cff77c" id="ue3cff77c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="ud5dae564" id="ud5dae564" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">964 个导出函数</span></strong><span data-lake-id="u76864c64" id="u76864c64" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，但实际上只有其中一个用于恶意执行的入口点。有趣的是，它的**导出目录（Export Directory）**存在 RVA 重复的现象：每一对导出函数共享相同的 RVA。这意味着该 DLL 实际上“仅”包含</span><span data-lake-id="ua1e0d979" id="ua1e0d979" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="ucb6647a2" id="ucb6647a2" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">482 个唯一导出项</span></strong><span data-lake-id="ufb4bf195" id="ufb4bf195" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。</span></p><p data-lake-id="u53800245" id="u53800245" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fresearch.checkpoint.com%2Fwp-content%2Fuploads%2F2025%2F04%2FLX79FK4NVZ-image5.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A859%2C%22originHeight%22%3A401%2C%22ratio%22%3A1%2C%22status%22%3A%22done%22%2C%22style%22%3A%22none%22%2C%22showTitle%22%3Afalse%2C%22title%22%3A%22%22%2C%22rotation%22%3A0%2C%22crop%22%3A%5B0%2C0%2C1%2C1%5D%2C%22id%22%3A%22m4YWx%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D"></card></p><p data-lake-id="u515c65a0" id="u515c65a0" style="text-align: justify"><span data-lake-id="ucff504e5" id="ucff504e5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Figure 5 – WINELOADER – “vmtools.dll” Exports.</span></p><p data-lake-id="u6a19f329" id="u6a19f329" style="text-align: justify"><span data-lake-id="uf2ad55df" id="uf2ad55df" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">另一个显著特征是</span><span data-lake-id="u9915c888" id="u9915c888" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ud67ca9f1" id="ud67ca9f1" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">.text</span><span data-lake-id="u0b50c5b4" id="u0b50c5b4" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u5181a940" id="u5181a940" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">段被标记为 “</span><strong><span data-lake-id="u7bb2b639" id="u7bb2b639" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">RWX</span></strong><span data-lake-id="u96d2d1f3" id="u96d2d1f3" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">”（可读-可写-可执行）。这强烈表明该代码具备</span><strong><span data-lake-id="u2cb68a44" id="u2cb68a44" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">自修改能力</span></strong><span data-lake-id="ue98c6c8e" id="ue98c6c8e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，通常是</span><strong><span data-lake-id="u0f52e0f8" id="u0f52e0f8" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">解包过程</span></strong><span data-lake-id="u57156355" id="u57156355" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的一部分。</span></p><p data-lake-id="uf76e698c" id="uf76e698c" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fresearch.checkpoint.com%2Fwp-content%2Fuploads%2F2025%2F04%2FLX79FK4NVZ-image6.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A881%2C%22originHeight%22%3A169%2C%22ratio%22%3A1%2C%22status%22%3A%22done%22%2C%22style%22%3A%22none%22%2C%22showTitle%22%3Afalse%2C%22title%22%3A%22%22%2C%22rotation%22%3A0%2C%22crop%22%3A%5B0%2C0%2C1%2C1%5D%2C%22id%22%3A%22p2Fqj%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D"></card></p><p data-lake-id="ua2b451eb" id="ua2b451eb" style="text-align: justify"><span data-lake-id="ue2303337" id="ue2303337" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Figure 6 – WINELOADER – “vmtools.dll” RWX “.text” section.</span></p><p data-lake-id="u5fa45743" id="u5fa45743" style="text-align: justify"><span data-lake-id="u27925ac2" id="u27925ac2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">该 DLL 名称为</span><span data-lake-id="u9d536711" id="u9d536711" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u429e6f9e" id="u429e6f9e" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">vmtools.dll</span><span data-lake-id="uf670a2dc" id="uf670a2dc" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，结合其导出函数的命名方式，表明它被设计用于与一个</span><strong><span data-lake-id="u54d4b844" id="u54d4b844" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">良性但存在漏洞的可执行文件</span></strong><span data-lake-id="ub68952f0" id="ub68952f0" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">一起部署，利用</span><span data-lake-id="ua917f653" id="ua917f653" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="uaf5e5855" id="uaf5e5855" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">DLL 侧加载（DLL Side-loading）</span></strong><span data-lake-id="uda39a7e6" id="uda39a7e6" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u05100b1c" id="u05100b1c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">来执行恶意代码。</span></p><p data-lake-id="u1d36b003" id="u1d36b003" style="text-align: justify"><span data-lake-id="u63125c29" id="u63125c29" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">尽管我们未能获取用于加载该 DLL 的确切主模块，但研究很快发现，一个具有相同 DLL 名称和导出函数的类似库，常被</span><span data-lake-id="ub874bd54" id="ub874bd54" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u9086c8e5" id="u9086c8e5" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">VMWare Tools 安装程序</span><span data-lake-id="u65999866" id="u65999866" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uc5f8e526" id="uc5f8e526" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">中的可执行文件使用。</span></p><p data-lake-id="u61f18a5c" id="u61f18a5c" style="text-align: justify"><span data-lake-id="u8d87881c" id="u8d87881c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">不过，找到这个漏洞模块的正确版本是一个挑战。由于该 DLL 是被</span><strong><span data-lake-id="u5b112b53" id="u5b112b53" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">木马化</span></strong><span data-lake-id="u34857eb6" id="u34857eb6" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的，其大多数导出函数中包含</span><strong><span data-lake-id="u957ff1a9" id="u957ff1a9" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">垃圾指令</span></strong><span data-lake-id="ud1a81462" id="ud1a81462" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，导致在加载器触发某个损坏的导出函数前，难以识别真正的目标函数。整个过程就像是在大海捞针。</span></p><p data-lake-id="u99739d37" id="u99739d37" style="text-align: justify"><span data-lake-id="u0cdefcbe" id="u0cdefcbe" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">为了解决这个问题，我们采用了</span><strong><span data-lake-id="u6b4ed39e" id="u6b4ed39e" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">模拟执行（emulation）方法</span></strong><span data-lake-id="u842cf53b" id="u842cf53b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，对所有导出函数进行</span><strong><span data-lake-id="ue0bf5a8c" id="ue0bf5a8c" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">系统化的暴力测试（brute-force）</span></strong><span data-lake-id="u327f54a9" id="u327f54a9" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，同时监控是否出现</span><strong><span data-lake-id="ubd21f745" id="ubd21f745" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">行为异常</span></strong><span data-lake-id="u7145e6bc" id="u7145e6bc" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。这种策略迅速帮助我们定位到了目标函数</span><span data-lake-id="ue80a5f30" id="ue80a5f30" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u6bb70664" id="u6bb70664" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">Str_Wcscpy</span><span data-lake-id="u4d3498ef" id="u4d3498ef" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，它会触发恶意执行。</span></p><h3 data-lake-id="Q9j4F" id="Q9j4F" style="text-align: left"><strong><span data-lake-id="u6f92b6e9" id="u6f92b6e9" style="color: rgb(15, 76, 129)">WINELOADER 解包过程</span></strong></h3><p data-lake-id="u329ca910" id="u329ca910" style="text-align: justify"><span data-lake-id="ub4199705" id="ub4199705" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">对</span><span data-lake-id="uf45f9448" id="uf45f9448" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uf9074122" id="uf9074122" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">Str_Wcscpy</span><span data-lake-id="u6f87fe4d" id="u6f87fe4d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ufe0bf5f5" id="ufe0bf5f5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的深入分析确认，它作为解包例程，与</span><span data-lake-id="ud3c56b43" id="ud3c56b43" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">先前的 WINELOADER 版本</span><span data-lake-id="u12c0ba77" id="u12c0ba77" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">中观察到的类似。</span></p><p data-lake-id="uebde71a7" id="uebde71a7" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fresearch.checkpoint.com%2Fwp-content%2Fuploads%2F2025%2F04%2FLX79FK4NVZ-image7.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A998%2C%22originHeight%22%3A632%2C%22ratio%22%3A1%2C%22status%22%3A%22done%22%2C%22style%22%3A%22none%22%2C%22showTitle%22%3Afalse%2C%22title%22%3A%22%22%2C%22rotation%22%3A0%2C%22crop%22%3A%5B0%2C0%2C1%2C1%5D%2C%22id%22%3A%22ZDyH7%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D"></card></p><p data-lake-id="u59ffea91" id="u59ffea91" style="text-align: justify"><span data-lake-id="u54015a8f" id="u54015a8f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Figure 7 – WINELOADER – Unpacking routine – new vs. previous version.</span></p><p data-lake-id="ubd55458b" id="ubd55458b" style="text-align: justify"><span data-lake-id="uca863a32" id="uca863a32" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">与早期版本一样，</span><strong><span data-lake-id="ufdec68f2" id="ufdec68f2" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">核心模块</span></strong><span data-lake-id="u9f562d1f" id="u9f562d1f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">通过</span><strong><span data-lake-id="ub35eb81b" id="ub35eb81b" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">RC4 解密</span></strong><span data-lake-id="u005a9cf0" id="u005a9cf0" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">进行解包，使用</span><strong><span data-lake-id="u9668d4ec" id="u9668d4ec" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">硬编码的 256 字节密钥</span></strong><span data-lake-id="u570628cb" id="u570628cb" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">（见</span><strong><span data-lake-id="ufdca39d3" id="ufdca39d3" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">附录 A</span></strong><span data-lake-id="ue9666321" id="ue9666321" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">）。相同的 RC4 密钥和算法也用于字符串解密和 C2 通信。</span></p><p data-lake-id="u0ff6a273" id="u0ff6a273" style="text-align: justify"><strong><span data-lake-id="uca518204" id="uca518204" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">C2 通信</span></strong></p><p data-lake-id="u31a29f3f" id="u31a29f3f" style="text-align: justify"><span data-lake-id="ucbdd231b" id="ucbdd231b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">解包后，WINELOADER 的核心模块从感染的机器中收集环境信息，包括：</span><span data-lake-id="ua58c3544" id="ua58c3544" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">IPAddress</span><span data-lake-id="uf69566d0" id="uf69566d0" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">、</span><span data-lake-id="u540822db" id="u540822db" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">ProcessName</span><span data-lake-id="u32fdd8a8" id="u32fdd8a8" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">、</span><span data-lake-id="u215239d3" id="u215239d3" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">UserName</span><span data-lake-id="u2ef75f6d" id="u2ef75f6d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">、</span><span data-lake-id="uc6a39e16" id="uc6a39e16" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">ComputerName</span><span data-lake-id="u65e011d7" id="u65e011d7" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">、</span><span data-lake-id="ufdf4ec60" id="ufdf4ec60" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">ProcessPID</span><span data-lake-id="uf38f24b4" id="uf38f24b4" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">、</span><span data-lake-id="ueac1067b" id="ueac1067b" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">ProcessToken</span><span data-lake-id="u1efdb461" id="u1efdb461" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，并将数据组织如下：</span></p><card type="inline" name="codeblock" value="data:%7B%22search%22%3A%22%22%2C%22mode%22%3A%22plain%22%2C%22code%22%3A%22struct%20CollectedEnvironmentInfo%5Cn%7B%5Cn%20%20%20%20WORD%20PaddingLength%3B%5Cn%20%20%20%20BYTE%20PaddingBytes%5BPaddingLength%5D%3B%5Cn%20%20%20%20QWORD%20PossibleCampaignID%3B%5Cn%20%20%20%20QWORD%20PossibleSessionID%3B%5Cn%20%20%20%20BYTE%20IPAddress%5B14%5D%3B%5Cn%20%20%20%20BYTE%20ProcessName%5B512%5D%3B%5Cn%20%20%20%20BYTE%20UserName%5B512%5D%3B%5Cn%20%20%20%20BYTE%20ComputerName%5B30%5D%3B%5Cn%20%20%20%20DWORD%20ProcessPID%3B%5Cn%20%20%20%20BYTE%20ProcessTokenElevationType%3B%5Cn%20%20%20%20QWORD%20PollingInterval%3B%5Cn%20%20%20%20BYTE%20RequestType%3B%5Cn%20%20%20%20QWORD%20MessageLength%3B%5Cn%20%20%20%20QWORD%20Unknown%3B%5Cn%20%20%20%20QWORD%20PossibleModuleID%3B%5Cn%20%20%20%20BYTE%20Message%5BMessageLength%5D%3B%5Cn%7D%3B%22%2C%22autoWrap%22%3Afalse%2C%22lineNumbers%22%3Atrue%2C%22heightLimit%22%3Atrue%2C%22collapsed%22%3Afalse%2C%22hideToolbar%22%3Afalse%2C%22name%22%3A%22%22%2C%22tabSize%22%3Anull%2C%22indentWithTab%22%3Afalse%2C%22lightLines%22%3A%5B%5D%2C%22foldLines%22%3A%5B%5D%2C%22customStyle%22%3A%5B%5D%2C%22theme%22%3A%22Github%20Light%22%2C%22__spacing%22%3A%22both%22%2C%22id%22%3A%22Eaurt%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D"></card><p data-lake-id="u175cfe76" id="u175cfe76" style="text-align: justify"><span data-lake-id="u4d13ec90" id="u4d13ec90" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">这个结构与</span><span data-lake-id="u4c4cecb1" id="u4c4cecb1" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">早期 WINELOADER 版本</span><span data-lake-id="u12064cd9" id="u12064cd9" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">中看到的几乎</span><strong><span data-lake-id="ubeb799dd" id="ubeb799dd" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">完全相同</span></strong><span data-lake-id="u2a93d7e8" id="u2a93d7e8" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。最初，这些数据使用内嵌的硬编码密钥（见</span><strong><span data-lake-id="ubd75f8c3" id="ubd75f8c3" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">附录 A</span></strong><span data-lake-id="u3ca7db2d" id="u3ca7db2d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">）进行</span><strong><span data-lake-id="u5caa141b" id="u5caa141b" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">RC4 加密</span></strong><span data-lake-id="ued6ba641" id="ued6ba641" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，然后通过</span><strong><span data-lake-id="u8df98249" id="u8df98249" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">HTTPS GET</span></strong><span data-lake-id="u6e3d51ef" id="u6e3d51ef" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">请求传输到 C2 服务器</span><span data-lake-id="u836fadf7" id="u836fadf7" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ue037401c" id="ue037401c" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">https[:]//bravecup[.]com/view.php</span><span data-lake-id="ufb54a8cb" id="ufb54a8cb" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，并使用</span><strong><span data-lake-id="u8a967cf0" id="u8a967cf0" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">User-Agent</span></strong><span data-lake-id="u477f889c" id="u477f889c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">字符串</span><span data-lake-id="u8ccdaefa" id="u8ccdaefa" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ue0b675f3" id="ue0b675f3" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.2151.25 Safari/537.36 Edg/119.0.2151.25</span><span data-lake-id="uf1a506f2" id="uf1a506f2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。</span></p><p data-lake-id="u0468f528" id="u0468f528" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fresearch.checkpoint.com%2Fwp-content%2Fuploads%2F2025%2F04%2FLX79FK4NVZ-image8.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A1823%2C%22originHeight%22%3A884%2C%22ratio%22%3A1%2C%22status%22%3A%22done%22%2C%22style%22%3A%22none%22%2C%22showTitle%22%3Afalse%2C%22title%22%3A%22%22%2C%22rotation%22%3A0%2C%22crop%22%3A%5B0%2C0%2C1%2C1%5D%2C%22id%22%3A%22Kbe6k%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D"></card></p><p data-lake-id="u50a9b7eb" id="u50a9b7eb" style="text-align: justify"><span data-lake-id="u799d434b" id="u799d434b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Figure 8 – WINELOADER C2 Communication</span></p><p data-lake-id="u95b9dbec" id="u95b9dbec" style="text-align: justify"><span data-lake-id="uea55a636" id="uea55a636" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">一个非常</span><strong><span data-lake-id="u1873da37" id="u1873da37" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">不寻常</span></strong><span data-lake-id="u60194d4b" id="u60194d4b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的方面是</span><strong><span data-lake-id="u1bcf5eec" id="u1bcf5eec" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">User-Agent</span></strong><span data-lake-id="u59346f99" id="u59346f99" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">字符串，它声称来自运行</span><strong><span data-lake-id="u07186b14" id="u07186b14" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">Microsoft Edge (v119.0.2151.25)*</span></strong><strong><em><span data-lake-id="u6b6bb4a1" id="u6b6bb4a1" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">的*</span></em></strong><strong><em><span data-lake-id="ua6f5ec76" id="ua6f5ec76" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">Windows 7</span></em></strong><strong><span data-lake-id="ue5b8992a" id="ue5b8992a" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">；该版本</span></strong><span data-lake-id="u1fec5b16" id="u1fec5b16" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">通常不应存在**于此操作系统上。这个异常作为一个强烈的网络妥协指示器（IoC）。</span></p><p data-lake-id="u016b3768" id="u016b3768" style="text-align: justify"><strong><span data-lake-id="u0102109f" id="u0102109f" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">演变中的反分析技术</span></strong></p><p data-lake-id="u4e7a2181" id="u4e7a2181" style="text-align: justify"><span data-lake-id="u5fa3ddfe" id="u5fa3ddfe" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">较旧的WINELOADER版本依赖于</span><strong><span data-lake-id="u0714b931" id="u0714b931" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">函数内联</span></strong><span data-lake-id="u28996631" id="u28996631" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">来进行字符串解密，并且</span><strong><span data-lake-id="ue57e803c" id="ue57e803c" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">没有</span></strong><span data-lake-id="u9363c828" id="u9363c828" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">严格执行即时的</span><strong><span data-lake-id="u6b25b89c" id="u6b25b89c" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">内存清理</span></strong><span data-lake-id="ue334bac9" id="ue334bac9" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，而是重用了局部变量。相比之下，新的变种采用了不同的方法，</span><strong><span data-lake-id="u651fc9b7" id="u651fc9b7" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">类似于GRAPELOADER</span></strong><span data-lake-id="u14e1846d" id="u14e1846d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">（表明存在</span><strong><span data-lake-id="ued32e020" id="ued32e020" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">代码库重叠</span></strong><span data-lake-id="ueb0d2f27" id="ueb0d2f27" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">或</span><strong><span data-lake-id="ue4269a8c" id="ue4269a8c" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">共享开发策略</span></strong><span data-lake-id="u8c684a90" id="u8c684a90" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">）。每个字符串都通过三个不同的函数进行处理：一个获取加密的字节块，另一个使用RC4算法解密它，最后一个函数在使用后立即将解密的内存置零。</span></p><p data-lake-id="ub1ad8d94" id="ub1ad8d94" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fresearch.checkpoint.com%2Fwp-content%2Fuploads%2F2025%2F04%2FLX79FK4NVZ-image9.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A1749%2C%22originHeight%22%3A748%2C%22ratio%22%3A1%2C%22status%22%3A%22done%22%2C%22style%22%3A%22none%22%2C%22showTitle%22%3Afalse%2C%22title%22%3A%22%22%2C%22rotation%22%3A0%2C%22crop%22%3A%5B0%2C0%2C1%2C1%5D%2C%22id%22%3A%22xfb5R%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D"></card></p><p data-lake-id="ua04df610" id="ua04df610" style="text-align: justify"><span data-lake-id="uc0817c61" id="uc0817c61" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Figure 9 – WINELOADER C2 communication string decryption: new vs. old version.</span></p><p data-lake-id="u293c464e" id="u293c464e" style="text-align: justify"><span data-lake-id="u70133f1e" id="u70133f1e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">之前，像</span><span data-lake-id="ud4324258" id="ud4324258" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">FLOSS</span><span data-lake-id="u5bc639d2" id="u5bc639d2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">这样的自动化工具可以轻松地从</span><strong><span data-lake-id="uac4d63cc" id="uac4d63cc" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">解包</span></strong><span data-lake-id="u8cae56d0" id="u8cae56d0" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的WINELOADER样本中提取和去混淆字符串。而新变种中的改进实现破坏了这一过程，导致自动化的字符串提取和去混淆失败。</span></p><p data-lake-id="ua68e2ab3" id="ua68e2ab3" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fresearch.checkpoint.com%2Fwp-content%2Fuploads%2F2025%2F04%2FLX79FK4NVZ-image10.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A1604%2C%22originHeight%22%3A538%2C%22ratio%22%3A1%2C%22status%22%3A%22done%22%2C%22style%22%3A%22none%22%2C%22showTitle%22%3Afalse%2C%22title%22%3A%22%22%2C%22rotation%22%3A0%2C%22crop%22%3A%5B0%2C0%2C1%2C1%5D%2C%22id%22%3A%22WQMz8%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D"></card></p><p data-lake-id="u701c4508" id="u701c4508" style="text-align: justify"><span data-lake-id="udd5f6b45" id="udd5f6b45" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Figure 10 – WINELOADER FLOSS string deobfuscation: old vs. new (unpacked samples).</span></p><p data-lake-id="ua03e4005" id="ua03e4005" style="text-align: justify"><span data-lake-id="u528ceb04" id="u528ceb04" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">除了字符串混淆，新版WINELOADER还改进了其他反分析技术，包括代码变异、垃圾指令插入和结构混淆。尽管这些变化阻碍了静态分析，但核心恶意软件功能和网络C2通信与之前的版本大致相同。</span></p><h2 data-lake-id="L2qe1" id="L2qe1" style="text-align: center"><span data-lake-id="ua880dfd5" id="ua880dfd5" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">归因</span></h2><p data-lake-id="uce2c0b77" id="uce2c0b77" style="text-align: justify"><span data-lake-id="u80c1ba70" id="u80c1ba70" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">本次活动中观察到的战术、技术和程序（TTPs）与2024年3月的</span><span data-lake-id="u7a2afac2" id="u7a2afac2" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">前一版本</span><span data-lake-id="ub2f0aaf2" id="ub2f0aaf2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u0023dc53" id="u0023dc53" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">WINELOADER活动非常相似。在那次攻击中，APT29同样通过伪装成葡萄酒品鉴会邀请的钓鱼邮件发起攻击，当时伪装成印度大使。</span></p><p data-lake-id="udb790c8a" id="udb790c8a" style="text-align: justify"><span data-lake-id="u8c14c3d0" id="u8c14c3d0" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">尽管本次活动中对感染链做了一些修改，例如引入GRAPELOADER作为初始阶段工具，而不是之前使用的ROOTSAW（一个HTA下载器），但核心执行方法——利用DLL侧加载和持久化技术——保持不变。</span></p><p data-lake-id="uc83f95b3" id="uc83f95b3" style="text-align: justify"><span data-lake-id="ua048cac2" id="ua048cac2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">此外，正如我们在本报告中展示的，GRAPELOADER与WINELOADER有显著相似之处，WINELOADER是APT29的标志性恶意软件。这些相似之处包括编译环境（Rich-PE）的对齐、匹配的编译时间戳以及相似的代码，如字符串加密机制。</span></p><h2 data-lake-id="yfbST" id="yfbST" style="text-align: center"><span data-lake-id="u34241f76" id="u34241f76" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">结论</span></h2><p data-lake-id="ub83bdf31" id="ub83bdf31" style="text-align: justify"><span data-lake-id="u57daafa3" id="u57daafa3" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">本报告深入分析了针对欧洲政府和外交机构的新一波定向钓鱼攻击。这些攻击与俄罗斯相关的APT29（也称为Midnight Blizzard或Cozy Bear）有关。攻击者伪装成欧洲某国外交部，发送伪造的葡萄酒品鉴邀请，部署一种新型恶意软件GRAPELOADER。该工具作为初始阶段机制，用于指纹识别、持久化和载荷投递。</span></p><p data-lake-id="ue234dc1a" id="ue234dc1a" style="text-align: justify"><span data-lake-id="u153b14da" id="u153b14da" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">此外，我们还发现了先前已知的WINELOADER恶意软件的新变种。新变种的变化主要体现在进化的隐匿和规避技术上，进一步增加了检测的难度。由于我们发现GRAPELOADER与WINELOADER之间的联系，这表明WINELOADER可能会在攻击的后续阶段被投递。</span></p><h2 data-lake-id="Q4qi4" id="Q4qi4" style="text-align: center"><span data-lake-id="u9146c20c" id="u9146c20c" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">保护措施</span></h2><p data-lake-id="uef25ce37" id="uef25ce37" style="text-align: justify"><span data-lake-id="u42efafc3" id="u42efafc3" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Check Point Threat Emulation 和 Harmony Endpoint 提供了全面的攻击战术、文件类型和操作系统覆盖，并能防护本报告中描述的攻击和威胁。</span></p><p data-lake-id="ucb708b06" id="ucb708b06" style="text-align: justify"><strong><span data-lake-id="uefab4932" id="uefab4932" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">Harmony Endpoint</span></strong><strong><span data-lake-id="ubd894fb9" id="ubd894fb9" class="lake-fontsize-11" style="color: rgb(15, 76, 129)"> </span></strong><strong><span data-lake-id="u7766962f" id="u7766962f" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">– Anti-Bot</span></strong></p><ul list="ub7493d6d"><li fid="ufef06028" data-lake-id="u8616c74d" id="u8616c74d" style="text-align: left"><span data-lake-id="ue3e5e150" id="ue3e5e150" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• Trojan.WIN64.WINELOADER.A</span></li><li fid="ufef06028" data-lake-id="ue3e72b1d" id="ue3e72b1d" style="text-align: left"><span data-lake-id="u5592f672" id="u5592f672" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• Trojan.WIN64.WINELOADER.B</span></li><li fid="ufef06028" data-lake-id="u7762f25d" id="u7762f25d" style="text-align: left"><span data-lake-id="u4946388d" id="u4946388d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• Trojan.WIN64.WINELOADER.C</span></li><li fid="ufef06028" data-lake-id="u84d1dec6" id="u84d1dec6" style="text-align: left"><span data-lake-id="uac9cbf1c" id="uac9cbf1c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• Trojan.WIN64.WINELOADER.D</span></li><li fid="ufef06028" data-lake-id="ue61ebdf7" id="ue61ebdf7" style="text-align: left"><span data-lake-id="uaee0407d" id="uaee0407d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• Trojan.WIN64.WINELOADER.E</span></li></ul><p data-lake-id="u4095d15c" id="u4095d15c" style="text-align: justify"><strong><span data-lake-id="u159e8522" id="u159e8522" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">Threat Emulation</span></strong></p><ul list="uc2edf12a"><li fid="uede62d94" data-lake-id="u0675b247" id="u0675b247" style="text-align: left"><span data-lake-id="udc408fda" id="udc408fda" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• APT.Wins.WineLoader.A</span></li><li fid="uede62d94" data-lake-id="u3bd54f19" id="u3bd54f19" style="text-align: left"><span data-lake-id="u463e71c6" id="u463e71c6" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• APT.Wins.WineLoader.B</span></li></ul><h2 data-lake-id="kaIJv" id="kaIJv" style="text-align: center"><span data-lake-id="ud230cb34" id="ud230cb34" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">IOCs</span></h2><table data-lake-id="nyvfj" id="nyvfj" margin="true" class="lake-table" style="width: 750px"><colgroup><col width="250"><col width="250"><col width="250"></colgroup><tbody><tr data-lake-id="uf457f339" id="uf457f339"><td data-lake-id="ua375cfd8" id="ua375cfd8"><p data-lake-id="u154efb75" id="u154efb75" style="text-align: left"><span data-lake-id="ubcee4e59" id="ubcee4e59" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Name</span></p></td><td data-lake-id="uf598e536" id="uf598e536"><p data-lake-id="ub6be8947" id="ub6be8947" style="text-align: left"><span data-lake-id="u06d74468" id="u06d74468" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Value</span></p></td><td data-lake-id="u0adf864b" id="u0adf864b"><p data-lake-id="u222491b1" id="u222491b1" style="text-align: left"><span data-lake-id="uc5b9d8f9" id="uc5b9d8f9" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Description</span></p></td></tr><tr data-lake-id="u74e9dd11" id="u74e9dd11"><td data-lake-id="u966ce29c" id="u966ce29c"><p data-lake-id="u4a16b494" id="u4a16b494" style="text-align: left"><span data-lake-id="uc4b02852" id="uc4b02852" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">wine.zip</span></p></td><td data-lake-id="u0de9adac" id="u0de9adac"><p data-lake-id="u4286c7e8" id="u4286c7e8" style="text-align: left"><span data-lake-id="u2f6c49bc" id="u2f6c49bc" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">653db3b63bb0e8c2db675cd047b737cefebb1c955bd99e7a93899e2144d34358</span></p></td><td data-lake-id="u69e14f4f" id="u69e14f4f"><p data-lake-id="u685c7eb8" id="u685c7eb8" style="text-align: left"><span data-lake-id="u11049796" id="u11049796" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Initial access ZIP</span></p></td></tr><tr data-lake-id="ucd6c6fad" id="ucd6c6fad"><td data-lake-id="u2886a09b" id="u2886a09b"><p data-lake-id="u5c54d260" id="u5c54d260" style="text-align: left"><span data-lake-id="u17f76796" id="u17f76796" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">wine.exe</span></p></td><td data-lake-id="uaf22c055" id="uaf22c055"><p data-lake-id="ueb0ddb1f" id="ueb0ddb1f" style="text-align: left"><span data-lake-id="uc9f32047" id="uc9f32047" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">420d20cddfaada4e96824a9184ac695800764961bad7654a6a6c3fe9b1b74b9a</span></p></td><td data-lake-id="u8ff6d0b6" id="u8ff6d0b6"><p data-lake-id="uf313d3b7" id="uf313d3b7" style="text-align: left"><span data-lake-id="ub6f6bc92" id="ub6f6bc92" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">PowerPoint for side-loading</span></p></td></tr><tr data-lake-id="u605130f6" id="u605130f6"><td data-lake-id="u2ae1dc1f" id="u2ae1dc1f"><p data-lake-id="u656cb015" id="u656cb015" style="text-align: left"><span data-lake-id="u6c362e84" id="u6c362e84" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">AppvIsvSubsystems64.dll</span></p></td><td data-lake-id="u56c3d835" id="u56c3d835"><p data-lake-id="u9f3b99af" id="u9f3b99af" style="text-align: left"><span data-lake-id="u5a43316b" id="u5a43316b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">85484716a369b0bc2391b5f20cf11e4bd65497a34e7a275532b729573d6ef15e</span></p></td><td data-lake-id="u3764f9f3" id="u3764f9f3"><p data-lake-id="uc27f0458" id="uc27f0458" style="text-align: left"><span data-lake-id="u5c11ea23" id="u5c11ea23" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Junk code DLL serving as PowerPoint dependency</span></p></td></tr><tr data-lake-id="u0f3a4b82" id="u0f3a4b82"><td data-lake-id="u4f1443f8" id="u4f1443f8"><p data-lake-id="u2620b587" id="u2620b587" style="text-align: left"><span data-lake-id="uea0cdd5f" id="uea0cdd5f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">AppvIsvSubsystems64.dll</span></p></td><td data-lake-id="u67abc0f2" id="u67abc0f2"><p data-lake-id="u8b0805fb" id="u8b0805fb" style="text-align: left"><span data-lake-id="u989e2dc5" id="u989e2dc5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">78a810e47e288a6aff7ffbaf1f20144d2b317a1618bba840d42405cddc4cff41</span></p></td><td data-lake-id="u9d8cc22e" id="u9d8cc22e"><p data-lake-id="ufe3e1377" id="ufe3e1377" style="text-align: left"><span data-lake-id="u2c3775e2" id="u2c3775e2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Junk code DLL serving as PowerPoint dependency</span></p></td></tr><tr data-lake-id="u6309ce38" id="u6309ce38"><td data-lake-id="u5c5e4d7d" id="u5c5e4d7d"><p data-lake-id="uea30d457" id="uea30d457" style="text-align: left"><span data-lake-id="u5532f542" id="u5532f542" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">ppcore.dll</span></p></td><td data-lake-id="uc6e76e33" id="uc6e76e33"><p data-lake-id="ud38db1f3" id="ud38db1f3" style="text-align: left"><span data-lake-id="u18a6411f" id="u18a6411f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">d931078b63d94726d4be5dc1a00324275b53b935b77d3eed1712461f0c180164</span></p></td><td data-lake-id="ud0f162b2" id="ud0f162b2"><p data-lake-id="uc0fa6a08" id="uc0fa6a08" style="text-align: left"><span data-lake-id="u57e86590" id="u57e86590" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">GRAPELOADER</span></p></td></tr><tr data-lake-id="u58cf1fab" id="u58cf1fab"><td data-lake-id="u68286647" id="u68286647"><p data-lake-id="ue0d5e92c" id="ue0d5e92c" style="text-align: left"><span data-lake-id="u04787ea5" id="u04787ea5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">ppcore.dll</span></p></td><td data-lake-id="u3bd65e72" id="u3bd65e72"><p data-lake-id="u45904558" id="u45904558" style="text-align: left"><span data-lake-id="u88dda534" id="u88dda534" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">24c079b24851a5cc8f61565176bbf1157b9d5559c642e31139ab8d76bbb320f8</span></p></td><td data-lake-id="u96d33ffd" id="u96d33ffd"><p data-lake-id="u6a443b8f" id="u6a443b8f" style="text-align: left"><span data-lake-id="u0fa13728" id="u0fa13728" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">GRAPELOADER</span></p></td></tr><tr data-lake-id="uacf49a42" id="uacf49a42"><td data-lake-id="ua6e66ccd" id="ua6e66ccd"><p data-lake-id="ue56d0e24" id="ue56d0e24" style="text-align: left"><span data-lake-id="u6f03fae7" id="u6f03fae7" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">vmtools.dll</span></p></td><td data-lake-id="u84a74145" id="u84a74145"><p data-lake-id="uf62063ab" id="uf62063ab" style="text-align: left"><span data-lake-id="u2394b433" id="u2394b433" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">adfe0ef4ef181c4b19437100153e9fe7aed119f5049e5489a36692757460b9f8</span></p></td><td data-lake-id="u4109bf32" id="u4109bf32"><p data-lake-id="ue88124a5" id="ue88124a5" style="text-align: left"><span data-lake-id="ue6a3a734" id="ue6a3a734" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">WINELOADER</span></p></td></tr><tr data-lake-id="uf99d0dcb" id="uf99d0dcb"><td data-lake-id="ub0550799" id="ub0550799"><p data-lake-id="ud95674ae" id="ud95674ae" style="text-align: left"><span data-lake-id="u0e77ff62" id="u0e77ff62" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">hxxps://silry[.]com/inva.php</span></p></td><td data-lake-id="ud7324a77" id="ud7324a77"></td><td data-lake-id="u48d9385a" id="u48d9385a"><p data-lake-id="u5d4d9bd2" id="u5d4d9bd2" style="text-align: left"><span data-lake-id="u28801ef2" id="u28801ef2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Download URL</span></p></td></tr><tr data-lake-id="u96c1dfd9" id="u96c1dfd9"><td data-lake-id="u2ea7525e" id="u2ea7525e"><p data-lake-id="u7ac160ea" id="u7ac160ea" style="text-align: left"><span data-lake-id="u96df9922" id="u96df9922" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">hxxps://bakenhof[.]com/invb.php</span></p></td><td data-lake-id="ud4e98ace" id="ud4e98ace"></td><td data-lake-id="u50ebf287" id="u50ebf287"><p data-lake-id="u9d9da860" id="u9d9da860" style="text-align: left"><span data-lake-id="u582fd90b" id="u582fd90b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Download URL</span></p></td></tr><tr data-lake-id="uf5b90c10" id="uf5b90c10"><td data-lake-id="u7e7b4a7d" id="u7e7b4a7d"><p data-lake-id="uc12fd3a8" id="uc12fd3a8" style="text-align: left"><span data-lake-id="u2670017c" id="u2670017c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">bakenhof[.]com</span></p></td><td data-lake-id="u3b797b2d" id="u3b797b2d"></td><td data-lake-id="u7e5264a1" id="u7e5264a1"><p data-lake-id="u5db3353d" id="u5db3353d" style="text-align: left"><span data-lake-id="uea04718f" id="uea04718f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Phishing Domain</span></p></td></tr><tr data-lake-id="u21c8b866" id="u21c8b866"><td data-lake-id="u29b23dc6" id="u29b23dc6"><p data-lake-id="u38ba9fef" id="u38ba9fef" style="text-align: left"><span data-lake-id="u08cdda95" id="u08cdda95" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">silry[.]com</span></p></td><td data-lake-id="u950b3770" id="u950b3770"></td><td data-lake-id="ud58af972" id="ud58af972"><p data-lake-id="u73bcaa07" id="u73bcaa07" style="text-align: left"><span data-lake-id="u10f64677" id="u10f64677" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Phishing Domain</span></p></td></tr><tr data-lake-id="u197cdb87" id="u197cdb87"><td data-lake-id="uac4580e1" id="uac4580e1"><p data-lake-id="u08972c07" id="u08972c07" style="text-align: left"><span data-lake-id="u788ad7ad" id="u788ad7ad" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">ophibre[.]com</span></p></td><td data-lake-id="u2d834a6a" id="u2d834a6a"></td><td data-lake-id="ub771c45c" id="ub771c45c"><p data-lake-id="ue7d9e981" id="ue7d9e981" style="text-align: left"><span data-lake-id="u99be9dea" id="u99be9dea" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">C2</span></p></td></tr><tr data-lake-id="u04260310" id="u04260310"><td data-lake-id="ua12d7593" id="ua12d7593"><p data-lake-id="u2d46a1ab" id="u2d46a1ab" style="text-align: left"><span data-lake-id="u72361644" id="u72361644" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">bravecup[.]com</span></p></td><td data-lake-id="ucc84a4d5" id="ucc84a4d5"></td><td data-lake-id="u87958485" id="u87958485"><p data-lake-id="u95323afc" id="u95323afc" style="text-align: left"><span data-lake-id="uce248e8d" id="uce248e8d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">C2</span></p></td></tr></tbody></table><h2 data-lake-id="ZWXrg" id="ZWXrg" style="text-align: center"><span data-lake-id="u448542be" id="u448542be" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">附录 A：硬编码 WINELOADER RC4 密钥</span></h2><p data-lake-id="uecb953da" id="uecb953da" style="text-align: justify"><span data-lake-id="ufc21cbf3" id="ufc21cbf3" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">WINELOADER 内嵌的完整 256 字节 RC4 密钥，用于字符串解密、解包核心模块以及加密/解密恶意软件与 C2 服务器之间交换的信息。</span></p><p data-lake-id="u077fc555" id="u077fc555" style="text-align: left"><code data-lake-id="ud1fd1d83" id="ud1fd1d83"><span data-lake-id="u41a9f2d4" id="u41a9f2d4" class="lake-fontsize-11" style="color: rgb(10, 10, 10)">6b67857ca8a21f6dcb30f855b320140b3ab1c7be4a1615a27bc63cba86412e43b7cbcb9135c91b3c1892bd12934b19f5698ca3695363f58a3fc53abdbc8188a1645278d0f5a568a33c1178cfe03cc942c45bf6b0e133df55475ef4385291ed2d8535aeaecd17ccb965417ac5fd622eaaa9a8ab72599f35dfe859b434a889af1e7d99c8204226737a487965bf0e6591cfcd2d70552ac37916eea90a227dda5f7e75285e682277c3751fb97ab6f023636dd090da79c5827410bfc6b020f6dc8937115b9b7291a28c67c745a188684f72b70dee97af82da581884c13e1200091d938eaf12523f4019d2dbddb5ae7e92d0730db71e441d8edb64df173ac7b96f6add</span></code></p><p data-lake-id="u4b6eb5f0" id="u4b6eb5f0"><span data-lake-id="u3e2b1637" id="u3e2b1637" class="lake-fontsize-9" style="color: rgb(10, 10, 10)">​</span><br></p>

打赏我,让我更有动力~

2 条回复   |  直到 7个月前 | 254 次浏览

小瑟斯
发表于 7个月前

PHA+PHNwYW4+5rao55+l6K+G5LqGPC9zcGFuPjwvcD4=

评论列表

  • 加载数据中...

编写评论内容

sechacker
发表于 7个月前

PHA+PHNwYW4+5qyn5rSy5Lmf6KaB5byA5aeL54Ot6Ze56LW35p2l5LqG5ZWKPC9zcGFuPjwvcD4=

评论列表

  • 加载数据中...

编写评论内容
登录后才可发表内容
返回顶部 投诉反馈

© 2016 - 2025 掌控者 All Rights Reserved.