<p data-lake-id="ud6a547c0" id="ud6a547c0"><span data-lake-id="u30a69c71" id="u30a69c71" class="lake-fontsize-9" style="color: rgb(10, 10, 10)">​</span><br></p><h2 data-lake-id="vroKp" id="vroKp" style="text-align: center"><span data-lake-id="u1528f924" id="u1528f924" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">俄罗斯黑客利用微软 OAuth 进行钓鱼社工</span></h2><h5 data-lake-id="CkUAI" id="CkUAI" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fwww.volexity.com%2Fwp-content%2Fuploads%2F2025%2F04%2FVolexity-Blog-Phishing-for-Codes-Russian-Threat-Actors-Target-Microsoft-365-OAuth-Workflows.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A2060%2C%22originHeight%22%3A1078%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%22aku1N%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"></card><span data-lake-id="udb1928fb" id="udb1928fb" class="lake-fontsize-11" style="color: rgb(136, 136, 136)">Volexity Blog - Phishing for Codes - Russian Threat Actors Target Microsoft 365 OAuth Workflows</span></h5><h5 data-lake-id="hbaIf" id="hbaIf" style="text-align: left"><span data-lake-id="u4c29f80b" id="u4c29f80b" style="color: rgb(15, 76, 129)">关键要点</span></h5><ul list="u0c134833"><li fid="u98865c35" data-lake-id="ua5dcf3db" id="ua5dcf3db" style="text-align: left"><span data-lake-id="u63a2182e" id="u63a2182e" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)">•</span><span data-lake-id="u866b55ad" id="u866b55ad" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)"> </span><em><span data-lake-id="u5d8483cb" id="u5d8483cb" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)">自2025年3月初以来，Volexity 观察到多个俄罗斯威胁行为者密集攻击与乌克兰和人权相关的个人及组织。</span></em></li><li fid="u98865c35" data-lake-id="ua10c4ad4" id="ua10c4ad4" style="text-align: left"><span data-lake-id="uc6b14108" id="uc6b14108" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)">•</span><span data-lake-id="u8be3ce5d" id="u8be3ce5d" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)"> </span><em><span data-lake-id="ucdff1aaa" id="ucdff1aaa" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)">这些近期攻击采用了一种新技术，目的是滥用合法的 Microsoft OAuth 2.0 认证流程。</span></em></li><li fid="u98865c35" data-lake-id="u53e08687" id="u53e08687" style="text-align: left"><span data-lake-id="u714514f7" id="u714514f7" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)">•</span><span data-lake-id="uf6f44aaf" id="uf6f44aaf" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)"> </span><em><span data-lake-id="udeff29dd" id="udeff29dd" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)">攻击者伪装成多国欧洲官员，其中一起攻击甚至利用了一个被攻陷的乌克兰政府账户。</span></em></li><li fid="u98865c35" data-lake-id="u3d3cca41" id="u3d3cca41" style="text-align: left"><span data-lake-id="u2aad46c8" id="u2aad46c8" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)">•</span><span data-lake-id="u979b7147" id="u979b7147" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)"> </span><em><span data-lake-id="ude69ce82" id="ude69ce82" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)">攻击者通过 Signal 和 WhatsApp 与目标联系，邀请他们参加或注册与欧洲各国政治官员的私人会议或即将举行的活动。</span></em></li><li fid="u98865c35" data-lake-id="u637084d7" id="u637084d7" style="text-align: left"><span data-lake-id="u88c3d556" id="u88c3d556" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)">•</span><span data-lake-id="u55758b4c" id="u55758b4c" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)"> </span><em><span data-lake-id="u9642c5f5" id="u9642c5f5" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)">部分社会工程攻击试图诱导受害者点击托管在 Microsoft 365 基础设施上的链接。</span></em></li><li fid="u98865c35" data-lake-id="u905d60a9" id="u905d60a9" style="text-align: left"><span data-lake-id="u92b86d24" id="u92b86d24" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)">•</span><span data-lake-id="u9e162c97" id="u9e162c97" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)"> </span><em><span data-lake-id="ufdda25a6" id="ufdda25a6" class="lake-fontsize-11" style="color: rgb(63, 63, 63); background-color: rgb(247, 247, 247)">主要策略是诱骗受害者提供 Microsoft 授权码，这使攻击者能够访问受害者账户，将攻击者控制的设备加入 Entra ID（前身为 Azure AD），并下载邮件及其他账户相关数据。</span></em></li></ul><p data-lake-id="u8acb9866" id="u8acb9866" style="text-align: justify"><span data-lake-id="ufea89a3f" id="ufea89a3f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">自2025年3月初起，Volexity 观察到多个疑似俄罗斯威胁行为者正在展开高度定向的社会工程攻击，目标是获取特定人员的 Microsoft 365（M365）账户访问权限。这些活动紧随 Volexity 于2025年2月</span><span data-lake-id="ud208e143" id="ud208e143" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u6f132446" id="u6f132446" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">发布的报告</span><span data-lake-id="u4b654497" id="u4b654497" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，当时披露了俄罗斯威胁行为者利用设备码认证钓鱼攻击用户与组织的行为。</span></p><p data-lake-id="u77d44b19" id="u77d44b19" style="text-align: justify"><span data-lake-id="ue0c6e9e2" id="ue0c6e9e2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">在该报告发布后，虽然威胁者使用设备码钓鱼的情况有所减少，但 Volexity 观察到他们正在转向滥用其他合法的 M365 OAuth 认证流程的新攻击方式。这些近期攻击高度依赖与目标的一对一互动，因为攻击者不仅需要说服目标点击链接，还要让他们返回 Microsoft 生成的授权码。</span></p><p data-lake-id="u0500c9b9" id="u0500c9b9" style="text-align: justify"><span data-lake-id="ucfcca6ae" id="ucfcca6ae" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Volexity 目前正在追踪至少两个被认为是俄罗斯的威胁行为者，分别标记为</span><span data-lake-id="u4317eb2e" id="u4317eb2e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u51708058" id="u51708058" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">UTA0352</span></strong><span data-lake-id="ub833706f" id="ub833706f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u100d098a" id="u100d098a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">和</span><span data-lake-id="ua497033d" id="ua497033d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u9944d6d1" id="u9944d6d1" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">UTA0355</span></strong><span data-lake-id="uea5ed38d" id="uea5ed38d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。这些行为者被认为是此次攻击的幕后主使。可以合理推测，这些威胁行为者与 Volexity 早前在 2025 年 1 月和 2 月披露的设备码认证钓鱼攻击中的行为者存在重叠。本博客将详细介绍这些威胁行为者使用的不同技术手法，以及它们攻击活动中的共性，概括如下：</span></p><ul list="u3f1dd006"><li fid="u6146b3ba" data-lake-id="u584ff581" id="u584ff581" style="text-align: left"><span data-lake-id="u20577223" id="u20577223" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 攻击者通过消息应用（如 Signal、WhatsApp）联系受害者，邀请其参加一次关于乌克兰冲突的视频会议；</span></li><li fid="u6146b3ba" data-lake-id="u11314764" id="u11314764" style="text-align: left"><span data-lake-id="u0b089eda" id="u0b089eda" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 一旦受害者回应，攻击者便发送一个 OAuth 钓鱼链接，声称这是加入会议所必需的；</span></li><li fid="u6146b3ba" data-lake-id="ucd646e38" id="ucd646e38" style="text-align: left"><span data-lake-id="ued3c6b37" id="ued3c6b37" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 受害者被要求将 Microsoft 生成的 OAuth 授权码返回给攻击者；</span></li><li fid="u6146b3ba" data-lake-id="u1a752208" id="u1a752208" style="text-align: left"><span data-lake-id="u5162b82f" id="u5162b82f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 如果受害者共享了授权码，攻击者即可生成访问令牌，从而访问受害者的 M365 账户。</span></li></ul><card type="block" name="hr" value="data:%7B%22id%22%3A%22rT2KI%22%7D"></card><h2 data-lake-id="FwBXE" id="FwBXE" style="text-align: center"><span data-lake-id="u672748ff" id="u672748ff" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">通向虚假的外交渠道</span></h2><p data-lake-id="uedc9367a" id="uedc9367a" style="text-align: justify"><span data-lake-id="u3552926e" id="u3552926e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">2025 年 3 月，Volexity 得知其部分客户的员工收到来自 Signal 和 WhatsApp 的可疑信息。被攻击的员工大多供职于支持人权的非政府组织，且具有处理与乌克兰相关问题的专业经验。这些消息自称来自欧洲政治官员，主题围绕讨论乌克兰相关事务展开。在每个已观察到的案例中，攻击者的“行动号召”是安排目标与其所声称代表国家的政治官员或大使进行会面。</span></p><p data-lake-id="ubdb25e57" id="ubdb25e57" style="text-align: justify"><span data-lake-id="u4f1d22cd" id="u4f1d22cd" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">如果目标回应消息，谈话通常很快会转向安排会议时间。为了避免引起怀疑，攻击者有时会以“大使当前不可用”为由，将会议安排在数天之后。</span></p><p data-lake-id="uf9bfb5f9" id="uf9bfb5f9" style="text-align: justify"><span data-lake-id="uc37e5060" id="uc37e5060" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">随着约定时间临近，这位所谓的欧洲政治官员会再次联系目标，并分享会议参与指南。这些指南通常以文档的形式通过消息平台发送，随后会附带一个加入会议的链接。这些链接均指向 Microsoft 365 的官方登录门户 ——</span><span data-lake-id="u52a7d842" id="u52a7d842" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="uaea9d093" id="uaea9d093" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">login.microsoftonline.com</span></strong><span data-lake-id="u84b320bf" id="u84b320bf" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。</span></p><p data-lake-id="u2709883c" id="u2709883c" style="text-align: justify"><span data-lake-id="uc7c11a3d" id="uc7c11a3d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">不出所料，这些链接实际上是钓鱼攻击的一部分，指南要求用户将某个授权码发回攻击者。但与此前观察到的攻击不同，这些 URL</span><span data-lake-id="ude34fae8" id="ude34fae8" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><em><span data-lake-id="u11652502" id="u11652502" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">并非</span></em><span data-lake-id="uc39d672a" id="uc39d672a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u7a92b665" id="u7a92b665" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">使用设备码认证流程，而是利用了与微软多个合法一方应用相关的其他 OAuth 2.0 认证流程。Volexity 将最早观察到的这批攻击归因于其标记为</span><span data-lake-id="ub8911329" id="ub8911329" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="ue17ed9c5" id="ue17ed9c5" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">UTA0352</span></strong><span data-lake-id="u3f0e9b98" id="u3f0e9b98" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u30439d0d" id="u30439d0d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的疑似俄罗斯威胁行为者。</span></p><p data-lake-id="uf1afb935" id="uf1afb935" style="text-align: justify"><span data-lake-id="u25f3c405" id="u25f3c405" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">在这些攻击中，单纯点击链接并不足以导致账户被攻陷。攻击者还需要受害者返回授权码。被点击的链接会跳转至微软官方页面，并在此过程中生成一个 Microsoft 授权码，该码可能会出现在 URI 中，或在某些情况下出现在重定向页面的正文中。攻击者随后可利用该授权码生成访问令牌，从而访问对应账户。在多个案例中，攻击者要求受害者通过电子邮件、WhatsApp 或 Signal 发送该授权码。</span></p><p data-lake-id="ua1da4de2" id="ua1da4de2" style="text-align: justify"><span data-lake-id="u91d70604" id="u91d70604" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Volexity 观察到</span><span data-lake-id="udf101055" id="udf101055" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u49d044ec" id="u49d044ec" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">UTA0352</span></strong><span data-lake-id="u8ba40d46" id="u8ba40d46" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u5c1ac81e" id="u5c1ac81e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">冒充了以下国家或组织的人员身份：</span></p><ul list="u918911c0"><li fid="ued85c337" data-lake-id="ud107fe24" id="ud107fe24" style="text-align: left"><span data-lake-id="uf5e1a01b" id="uf5e1a01b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">•</span><span data-lake-id="ua2920018" id="ua2920018" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u9bcd19ca" id="u9bcd19ca" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">乌克兰驻欧盟使团</span></strong></li><li fid="ued85c337" data-lake-id="u4f8b673c" id="u4f8b673c" style="text-align: left"><span data-lake-id="ube341c33" id="ube341c33" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">•</span><span data-lake-id="u50ec47ff" id="u50ec47ff" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="uf034f6ff" id="uf034f6ff" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">保加利亚共和国驻北约常驻代表团</span></strong></li><li fid="ued85c337" data-lake-id="u3a32dd65" id="u3a32dd65" style="text-align: left"><span data-lake-id="udc424e62" id="udc424e62" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">•</span><span data-lake-id="u40a2f618" id="u40a2f618" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u955211a5" id="u955211a5" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">罗马尼亚驻欧盟常驻代表团</span></strong></li></ul><p data-lake-id="u4997f36c" id="u4997f36c" style="text-align: justify"><span data-lake-id="u8e6295dc" id="u8e6295dc" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">根据其他观察结果，Volexity 还认为</span><span data-lake-id="u75429686" id="u75429686" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u40c45a1f" id="u40c45a1f" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">UTA0352</span></strong><span data-lake-id="u049f7f27" id="u049f7f27" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u53832b53" id="u53832b53" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">可能也冒充了</span><span data-lake-id="ud31f4837" id="ud31f4837" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="ua332df25" id="ua332df25" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">波兰</span></strong><span data-lake-id="u0fc2d92f" id="u0fc2d92f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ufe3bc929" id="ufe3bc929" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">官员，但这一点尚未直接证实。下方图片展示了</span><span data-lake-id="u31d6d6ef" id="u31d6d6ef" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u4c244f22" id="u4c244f22" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">UTA0352</span></strong><span data-lake-id="u94310d1c" id="u94310d1c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uae3a880d" id="uae3a880d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">在 Signal（左图）和 WhatsApp（右图）上冒充不同身份发送的初始消息示例。</span></p><p data-lake-id="u14cb6281" id="u14cb6281" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fwww.volexity.com%2Fwp-content%2Fuploads%2F2025%2F04%2FVolexity-UTA0352-Signal-and-WhatsApp-Messages-BG-NATO-UA.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A1000%2C%22originHeight%22%3A982%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%22qa7yf%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"></card></p><p data-lake-id="u3ac518ab" id="u3ac518ab" style="text-align: center"><span data-lake-id="u285405d9" id="u285405d9" class="lake-fontsize-11" style="color: rgb(136, 136, 136)">img</span></p><h3 data-lake-id="ZL3jm" id="ZL3jm" style="text-align: left"><span data-lake-id="u709827ad" id="u709827ad" style="color: rgb(63, 63, 63)">通过 Visual Studio Code 进行钓鱼攻击</span></h3><p data-lake-id="uf98570fc" id="uf98570fc" style="text-align: justify"><span data-lake-id="u454f940e" id="u454f940e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">2025 年 3 月中旬，Volexity 的一位客户收到了来自</span><span data-lake-id="u9df215d5" id="u9df215d5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="ub2de2bf9" id="ub2de2bf9" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">UTA0352</span></strong><span data-lake-id="ucef37bf7" id="ucef37bf7" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ubd4cc3e3" id="ubd4cc3e3" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的联系，攻击者自称是来自</span><span data-lake-id="u21397f20" id="u21397f20" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="uee0f030b" id="uee0f030b" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">罗马尼亚政府</span></strong><span data-lake-id="u6172c650" id="u6172c650" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u9a8df709" id="u9a8df709" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的官员，试图安排客户与其“大使”进行会面。一旦用户开始互动，攻击者便发送了一条信息，称需要通过其托管在“安全服务器”上的网页系统——</span><strong><span data-lake-id="u74424c38" id="u74424c38" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">扩展验证系统（EVS）</span></strong><span data-lake-id="u12b54f4a" id="u12b54f4a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u5019be85" id="u5019be85" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">来安排会议。</span></p><p data-lake-id="u68936fca" id="u68936fca" style="text-align: justify"><span data-lake-id="u32a984d8" id="u32a984d8" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">该信息还附带了一个 PDF 文件，文件中包含了用户应期待的内容及如何加入会议的说明。随后，攻击者向目标发送了一个经过恶意构造的 URL 链接。</span></p><p data-lake-id="udc0ef834" id="udc0ef834" style="text-align: justify"><span data-lake-id="u857595e1" id="u857595e1" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">下图展示的是该 PDF 文件的两个页面，文件伪装成由</span><strong><span data-lake-id="u9f4f331f" id="u9f4f331f" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">罗马尼亚外交部</span></strong><span data-lake-id="u388f8799" id="u388f8799" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">发布的官方文件。</span></p><p data-lake-id="u60b03eb4" id="u60b03eb4" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fwww.volexity.com%2Fwp-content%2Fuploads%2F2025%2F04%2FVolexity-uta0365-EVS-MFA-Romania-Spoof-1.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A1000%2C%22originHeight%22%3A646%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%22S8MNX%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"></card></p><p data-lake-id="u29cc7d66" id="u29cc7d66" style="text-align: center"><span data-lake-id="u3310b1b6" id="u3310b1b6" class="lake-fontsize-11" style="color: rgb(136, 136, 136)">img</span></p><p data-lake-id="ufddec485" id="ufddec485" style="text-align: justify"><span data-lake-id="u0bc2c0b9" id="u0bc2c0b9" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">UTA0352 分享的 URL 格式如下：</span></p><p data-lake-id="ua9fed56d" id="ua9fed56d" style="text-align: left"><span data-lake-id="u924e44b7" id="u924e44b7" class="lake-fontsize-11" style="color: rgb(10, 10, 10)">https://login.microsoftonline[.]com/organizations/oauth2/v2.0/authorize?state=https://mae.gov[.]ro/[REMOVED]&amp;client_id=aebc6443-996d-45c2-90f0-388ff96faa56&amp;scope=https://graph.microsoft.com/.default&amp;response_type=code&amp;redirect_uri=https://insiders.vscode.dev/redirect&amp;login_hint=&lt;EMAIL HERE&gt;</span></p><p data-lake-id="ua8dd81ed" id="ua8dd81ed" style="text-align: justify"><span data-lake-id="u369c264b" id="u369c264b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">该 URL 格式被 M365 用于通过其 OAuth 流程登录 Microsoft 原生/第一方应用程序以及第三方应用程序。URL 中的关键参数在</span><span data-lake-id="u7c961178" id="u7c961178" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u83f831c5" id="u83f831c5" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">Microsoft OAuth 官方文档</span><span data-lake-id="u05467dfc" id="u05467dfc" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ucbceb919" id="ucbceb919" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">中有详细说明；为方便起见，以下是对这些参数的简要介绍：</span></p><table data-lake-id="itsqk" id="itsqk" class="lake-table" style="width: 750px"><colgroup><col width="375"><col width="375"></colgroup><tbody><tr data-lake-id="ud01243d7" id="ud01243d7"><td data-lake-id="uf88d52a1" id="uf88d52a1"><p data-lake-id="u504120a8" id="u504120a8" style="text-align: left"><strong><span data-lake-id="uebe812d6" id="uebe812d6" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">Parameter</span></strong></p></td><td data-lake-id="u41304d51" id="u41304d51"><p data-lake-id="uc64c3c80" id="uc64c3c80" style="text-align: left"><strong><span data-lake-id="u2feba05e" id="u2feba05e" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">Description</span></strong></p></td></tr><tr data-lake-id="uf004241e" id="uf004241e"><td data-lake-id="uaff0057d" id="uaff0057d"><p data-lake-id="u8bdac63a" id="u8bdac63a" style="text-align: left"><span data-lake-id="ue7d274de" id="ue7d274de" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">state</span></p></td><td data-lake-id="u608a8462" id="u608a8462"><p data-lake-id="ub6171eb4" id="ub6171eb4" style="text-align: left"><span data-lake-id="u7a59e9e3" id="u7a59e9e3" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">A value to denote the user’s state in the application before the request occurred</span></p></td></tr><tr data-lake-id="u6749edbf" id="u6749edbf"><td data-lake-id="u2bc30b18" id="u2bc30b18"><p data-lake-id="u2955d76c" id="u2955d76c" style="text-align: left"><span data-lake-id="ua11a6777" id="ua11a6777" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">client_id</span></p></td><td data-lake-id="u88e9751e" id="u88e9751e"><p data-lake-id="u73062d7a" id="u73062d7a" style="text-align: left"><span data-lake-id="ubf32abed" id="ubf32abed" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">The application that made the request</span></p></td></tr><tr data-lake-id="ub905cbdb" id="ub905cbdb"><td data-lake-id="u72cf1e6c" id="u72cf1e6c"><p data-lake-id="u3507f3cb" id="u3507f3cb" style="text-align: left"><span data-lake-id="u8e056444" id="u8e056444" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">scope</span></p></td><td data-lake-id="uc8457370" id="uc8457370"><p data-lake-id="udfae9d40" id="udfae9d40" style="text-align: left"><span data-lake-id="u8973debc" id="u8973debc" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">The access level requested</span></p></td></tr><tr data-lake-id="u21b89b7a" id="u21b89b7a"><td data-lake-id="uc03d04bc" id="uc03d04bc"><p data-lake-id="u292b8a1e" id="u292b8a1e" style="text-align: left"><span data-lake-id="u3fd560fe" id="u3fd560fe" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">response_type</span></p></td><td data-lake-id="u8e143595" id="u8e143595"><p data-lake-id="ue6f81d45" id="ue6f81d45" style="text-align: left"><span data-lake-id="uf7a26f73" id="uf7a26f73" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">The method used to send the token back</span></p></td></tr><tr data-lake-id="u006860f6" id="u006860f6"><td data-lake-id="ufd55fcdd" id="ufd55fcdd"><p data-lake-id="u0578b693" id="u0578b693" style="text-align: left"><span data-lake-id="u1ec0c73f" id="u1ec0c73f" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">redirect_uri</span></p></td><td data-lake-id="uee7637ed" id="uee7637ed"><p data-lake-id="u734257e8" id="u734257e8" style="text-align: left"><span data-lake-id="u76e515fe" id="u76e515fe" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">The handling URI to receive the generated token afterwards</span></p></td></tr></tbody></table><p data-lake-id="u3398de23" id="u3398de23" style="text-align: justify"><span data-lake-id="u2fcfc904" id="u2fcfc904" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">如果用户已经使用</span><span data-lake-id="u391f929b" id="u391f929b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u762391aa" id="u762391aa" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">login_hint</span><span data-lake-id="uf63604b8" id="uf63604b8" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ue8f82c82" id="ue8f82c82" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">参数中指定的账户登录，他们将会被无缝重定向。如果用户尚未完成身份验证，则会被提示登录其 M365 账户。完成身份验证后，用户会被重定向至浏览器版本的 Visual Studio Code，托管于</span><span data-lake-id="u5e32d63f" id="u5e32d63f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="ub402eed5" id="ub402eed5" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">insiders.vscode.dev</span></strong><span data-lake-id="ue1fe2c95" id="ue1fe2c95" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。</span></p><p data-lake-id="u62bd2ab7" id="u62bd2ab7" style="text-align: justify"><span data-lake-id="ub2273800" id="ub2273800" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">该 URL 会将用户重定向至</span><span data-lake-id="u6d66a6eb" id="u6d66a6eb" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u83040c5a" id="u83040c5a" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">/redirect</span><span data-lake-id="u29ecfc9d" id="u29ecfc9d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u52953627" id="u52953627" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">页面，该页面的设计目的是接收来自 M365 的登录参数，包括 OAuth。当用户被重定向至此页面时，将会看到如下对话框：</span></p><p data-lake-id="u3fb0a44b" id="u3fb0a44b" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fwww.volexity.com%2Fwp-content%2Fuploads%2F2025%2F04%2Fvolexity-uta0352-insiders-vscode-dev.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A985%2C%22originHeight%22%3A656%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%22KmC0y%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"></card></p><p data-lake-id="uc8212154" id="uc8212154" style="text-align: center"><span data-lake-id="u177e1e6e" id="u177e1e6e" class="lake-fontsize-11" style="color: rgb(136, 136, 136)">img</span></p><p data-lake-id="u5eca3f0f" id="u5eca3f0f" style="text-align: justify"><span data-lake-id="u692b4750" id="u692b4750" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">通过 Visual Studio Code 对话框显示的代码是一个 OAuth 2.0 授权码，其有效期最长可达 60 天。该授权码可提交给 Microsoft 的 OAuth 流程以换取访问令牌（Access Token），进而用于访问 M365 Graph API。由于最初的请求申请了用户的默认访问权限，因此任何获得该授权码的人都将拥有与用户相同的</span><span data-lake-id="ud738d25f" id="ud738d25f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><em><span data-lake-id="u34f68821" id="u34f68821" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">全部资源访问权限</span></em><span data-lake-id="uc8bf32ea" id="uc8bf32ea" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">。需要注意的是，该代码也会出现在地址栏的 URI 中。Visual Studio Code 的这个页面似乎被特别设置，以便更方便地提取和共享该代码，而大多数其他实例中只会显示空白页面。</span></p><p data-lake-id="uf912437c" id="uf912437c" style="text-align: justify"><span data-lake-id="u30c9e7bd" id="u30c9e7bd" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">主标题下方显示的消息使用了前一个请求中的</span><span data-lake-id="uec3d405c" id="uec3d405c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u55857d59" id="u55857d59" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">state</span><span data-lake-id="u50b1f141" id="u50b1f141" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u31615da1" id="u31615da1" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">值，该值通常用于指示身份验证请求的来源。然而，正如 Microsoft 文档中所描述的，这个值是任意的。是否使用以及如何使用该值，完全取决于处理该请求的应用程序（在本例中是 Visual Studio Code）。UTA0352 滥用了这一参数，使其看起来像是在尝试登录一个罗马尼亚政府服务系统。这种手法在其他钓鱼攻击中也被反复使用，目的是让链接看起来更合法可信。</span></p><p data-lake-id="ue4b34164" id="ue4b34164" style="text-align: justify"><span data-lake-id="u75d27c77" id="u75d27c77" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">下图展示了攻击者利用 Visual Studio Code 第一方应用程序攻击用户时所遵循的整体流程。该流程与后续观察到的其他攻击略有不同，但整体上非常相似。</span></p><p data-lake-id="u62bc998f" id="u62bc998f" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fwww.volexity.com%2Fwp-content%2Fuploads%2F2025%2F04%2Fvolexity-uta0352-visual-studio-code-oauth-workflow.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A950%2C%22originHeight%22%3A721%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%22aUKpM%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"></card></p><p data-lake-id="u44450a3b" id="u44450a3b" style="text-align: center"><span data-lake-id="u1274f0c1" id="u1274f0c1" class="lake-fontsize-11" style="color: rgb(136, 136, 136)">img</span></p><h3 data-lake-id="wj9r3" id="wj9r3" style="text-align: left"><span data-lake-id="u18d6c993" id="u18d6c993" style="color: rgb(63, 63, 63)">更早版本的 Visual Studio Code 钓鱼攻击</span></h3><p data-lake-id="u501225ad" id="u501225ad" style="text-align: justify"><span data-lake-id="uffd1e8ae" id="uffd1e8ae" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">除了上文描述的钓鱼攻击外，Volexity 还发现了一个被认为是 UTA0352 早期使用的钓鱼活动变体。在这次早期的攻击活动中，使用了如下格式的 URL：</span></p><p data-lake-id="uf0bf886d" id="uf0bf886d" style="text-align: left"><span data-lake-id="ud757fd25" id="ud757fd25" class="lake-fontsize-11" style="color: rgb(10, 10, 10)">hxxps://login.microsoftonline[.]com/common/oauth2/authorize?redirect=https://zoom.us/j/&lt;snip&gt;&amp;client_id=aebc6443-996d-45c2-90f0-388ff96faa56&amp;resource=https://graph.microsoft.com&amp;response_type=code&amp;redirect_uri=https://vscode-redirect.azurewebsites.net&amp;login_hint=&lt;removed&gt;&amp;ui_locales=en-US&amp;mkt=en-US&amp;client-request-id=&lt;removed&gt;</span></p><p data-lake-id="ufb905bcc" id="ufb905bcc" style="text-align: justify"><span data-lake-id="u005d6632" id="u005d6632" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">该 URL 与前文所述的不同之处在于，它采用的是 AzureAD v1.0 规范的格式，而不是最初观察到的攻击中使用的 v2.0 规范。以下是两者在 URL 参数上的关键差异：</span></p><table data-lake-id="SB4Dn" id="SB4Dn" class="lake-table" style="width: 750px"><colgroup><col width="250"><col width="250"><col width="250"></colgroup><tbody><tr data-lake-id="u30571946" id="u30571946"><td data-lake-id="u2ea51c12" id="u2ea51c12"><p data-lake-id="ud8855611" id="ud8855611" style="text-align: left"><strong><span data-lake-id="u5a5fb6ec" id="u5a5fb6ec" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">Parameter</span></strong></p></td><td data-lake-id="u129d9b1f" id="u129d9b1f"><p data-lake-id="u7f8b5619" id="u7f8b5619" style="text-align: left"><strong><span data-lake-id="u3317ab9f" id="u3317ab9f" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">Initially Observed Campaign</span></strong></p></td><td data-lake-id="u98bda2de" id="u98bda2de"><p data-lake-id="u65708175" id="u65708175" style="text-align: left"><strong><span data-lake-id="u4988067d" id="u4988067d" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">Earlier Campaign Variation</span></strong></p></td></tr><tr data-lake-id="u1b05926d" id="u1b05926d"><td data-lake-id="u42eb69ab" id="u42eb69ab"><p data-lake-id="u1a86eaa8" id="u1a86eaa8" style="text-align: left"><span data-lake-id="ua0ba3787" id="ua0ba3787" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">redirect_uri</span></p></td><td data-lake-id="ue8cb5c7b" id="ue8cb5c7b"><p data-lake-id="uff2a04dc" id="uff2a04dc" style="text-align: left"><span data-lake-id="u78cfce31" id="u78cfce31" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Uses</span><span data-lake-id="ua2e196f9" id="ua2e196f9" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">insiders.vscode.dev</span></p></td><td data-lake-id="ua95a22b6" id="ua95a22b6"><p data-lake-id="ucb2bde69" id="ucb2bde69" style="text-align: left"><span data-lake-id="uec43a92c" id="uec43a92c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Uses</span><span data-lake-id="ud9b1d7e1" id="ud9b1d7e1" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ufd69500d" id="ufd69500d" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">vscode-redirect.azurewebsites.net</span><span data-lake-id="uf01705b4" id="uf01705b4" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">.</span></p></td></tr><tr data-lake-id="u6d6ffbb0" id="u6d6ffbb0"><td data-lake-id="u60fa4daf" id="u60fa4daf"><p data-lake-id="ud21de99a" id="ud21de99a" style="text-align: left"><span data-lake-id="uda3b0b09" id="uda3b0b09" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">resource</span></p></td><td data-lake-id="u8b5853b7" id="u8b5853b7"><p data-lake-id="ub874cfbb" id="ub874cfbb" style="text-align: left"><span data-lake-id="ue81f2692" id="ue81f2692" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">This is the scope parameter in the Oath 2.0 flow</span></p></td><td data-lake-id="ueb2cfba8" id="ueb2cfba8"><p data-lake-id="ub5467891" id="ub5467891" style="text-align: left"><span data-lake-id="u456f9dbb" id="u456f9dbb" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">This is the AzureAD v1.0 field used to define the resource for which access is required</span></p></td></tr><tr data-lake-id="ufcbe6353" id="ufcbe6353"><td data-lake-id="uface774d" id="uface774d"><p data-lake-id="u02f3d240" id="u02f3d240" style="text-align: left"><span data-lake-id="u37edcf61" id="u37edcf61" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">redirect</span></p></td><td data-lake-id="udfdcdc3d" id="udfdcdc3d"><p data-lake-id="uf54f14e1" id="uf54f14e1" style="text-align: left"><span data-lake-id="u49883203" id="u49883203" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Unused in the previously documented campaign</span></p></td><td data-lake-id="u18590d46" id="u18590d46"><p data-lake-id="ubd2d5267" id="ubd2d5267" style="text-align: left"><span data-lake-id="u912de013" id="u912de013" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">This parameter is included in the request to make it look like the user may be logging into a Zoom call, but it is unused in AzureAD v1.0 authentication workflows</span></p></td></tr></tbody></table><p data-lake-id="u7ca71d5f" id="u7ca71d5f" style="text-align: justify"><span data-lake-id="u2f3bfb2b" id="u2f3bfb2b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">早期版本的攻击活动启动的流程与最初观察到的攻击相似。如果用户已登录，他们将被重定向到</span><span data-lake-id="ub5d42295" id="ub5d42295" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="u036e2f93" id="u036e2f93" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">vscode-redirect.azurewebsites.net</span></strong><span data-lake-id="uc407b259" id="uc407b259" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">，该地址随后会重定向到本地 IP 地址 (127.0.0.1)。当这种情况发生时，不会显示包含授权码的用户界面，而是授权码仅通过 URL 提供。最终的 URL 格式如下：</span></p><p data-lake-id="u052922ca" id="u052922ca" style="text-align: left"><span data-lake-id="u5215829c" id="u5215829c" class="lake-fontsize-11" style="color: rgb(10, 10, 10)">hxxp://127.0.0.1:9217/callback?code=1.ARsAIGLD9ki0FE63WmhS-KbgFENkvK5tmX[snipped]D&amp;session_state=[uuid]</span></p><p data-lake-id="u2e8d8b1e" id="u2e8d8b1e" style="text-align: justify"><span data-lake-id="u9ace2768" id="u9ace2768" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">这会在用户的浏览器中渲染为空白页面。攻击者必须要求用户分享浏览器中的 URL，以便攻击者获取授权码。</span></p><h2 data-lake-id="ssZzx" id="ssZzx" style="text-align: center"><span data-lake-id="ube82d3db" id="ube82d3db" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">UTA0355：通过被攻击的乌克兰政府账户进行钓鱼</span></h2><p data-lake-id="ucacd986c" id="ucacd986c" style="text-align: justify"><span data-lake-id="uf948916e" id="uf948916e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">然后，在 2025 年 4 月初，Volexity 发现了另一起新的 Microsoft 365 OAuth 钓鱼活动。这次，攻击活动从一个合法的、被攻击的乌克兰政府电子邮件账户发送的电子邮件开始，随后通过 Signal 和 WhatsApp 发送了后续消息。电子邮件和后续消息邀请目标参加一个关于乌克兰努力“</span><em><span data-lake-id="u6694872f" id="u6694872f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">调查和起诉暴行犯罪，以及该国与国际伙伴在这一领域的合作</span></em><span data-lake-id="ua5116c80" id="ua5116c80" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">”的视频会议。</span></p><p data-lake-id="u013646dc" id="u013646dc" style="text-align: justify"><span data-lake-id="ub3539024" id="ub3539024" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">与 Volexity 之前报告的 OAuth 钓鱼技术类似，这次活动的最终目的是利用合法的 Microsoft 365 身份验证 API 获取受害者的电子邮件数据。然而，在这次活动中，攻击者使用盗取的 OAuth 授权码将受害者的设备永久注册到受害者的 Microsoft Entra ID（前身为 Azure Active Directory）中。设备注册到 Entra ID 后，攻击者还需要进一步通过社交工程让受害者批准两因素身份验证请求，以便访问受害者的电子邮件。</span></p><p data-lake-id="u9918fa6c" id="u9918fa6c" style="text-align: justify"><span data-lake-id="u058819d1" id="u058819d1" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">尽管这次活动使用了与 UTA0352 使用的技术类似的手段，Volexity 目前将这些攻击分别追踪，并将该活动归因于一个被标记为</span><span data-lake-id="u8a94758f" id="u8a94758f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="ufa22dd9b" id="ufa22dd9b" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">UTA0355</span></strong><span data-lake-id="uac848ad1" id="uac848ad1" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u70e0c6a6" id="u70e0c6a6" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的威胁演员。</span></p><h3 data-lake-id="ovJeY" id="ovJeY" style="text-align: left"><span data-lake-id="uf056fe1f" id="uf056fe1f" style="color: rgb(63, 63, 63)">多阶段社会工程学</span></h3><p data-lake-id="u3ff0b234" id="u3ff0b234" style="text-align: justify"><span data-lake-id="uc70532a1" id="uc70532a1" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">与 Volexity 观察到的 UTA0352 攻击不同，这次新的钓鱼活动首先通过电子邮件发送给多个目标。电子邮件邀请目标参加一个视频会议，并附有活动详情。邮件中没有包含任何链接或指示，但确实询问收件人是否有兴趣参加。然而，尽管初步接触是通过电子邮件进行的，Volexity 发现 UTA0355 很快通过 Signal 或 WhatsApp 跟进了每个收件人，提到了之前发送的电子邮件，可能是为了增加其信息的可信度。</span></p><p data-lake-id="u820d2105" id="u820d2105" style="text-align: justify"><span data-lake-id="u37214ea0" id="u37214ea0" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Volexity 认为，UTA0355 只向那些它有其他联系方式的目标发送了来自被攻击的乌克兰政府账户的电子邮件。这可能是为了促进实时对话，协助社交工程工作，并将信息保存在电子邮件之外，避免其更容易被发现或后期审查。</span></p><p data-lake-id="u30327130" id="u30327130" style="text-align: justify"><span data-lake-id="uba602237" id="uba602237" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">下图展示了发送给多个目标的初始电子邮件。</span></p><p data-lake-id="u6e22be41" id="u6e22be41" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fwww.volexity.com%2Fwp-content%2Fuploads%2F2025%2F04%2Fvolexity-uta0355-Ukraine-Govt-Email-Phish.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A955%2C%22originHeight%22%3A477%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%22gEiTQ%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"></card></p><p data-lake-id="u9fac8a06" id="u9fac8a06" style="text-align: center"><span data-lake-id="uf1da458e" id="uf1da458e" class="lake-fontsize-11" style="color: rgb(136, 136, 136)">img</span></p><p data-lake-id="ud972b9f6" id="ud972b9f6" style="text-align: justify"><span data-lake-id="u65160db2" id="u65160db2" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">在这封电子邮件发送给多个目标后不久，UTA0355 通过 Signal 或 WhatsApp 发送了提及该电子邮件的后续消息；下面是一个示例。</span></p><p data-lake-id="u9d6c2249" id="u9d6c2249" style="text-align: left"><card type="inline" name="image" value="data:%7B%22src%22%3A%22https%3A%2F%2Fwww.volexity.com%2Fwp-content%2Fuploads%2F2025%2F04%2Fvolexity-uta0355-signal-invite.png%22%2C%22originalType%22%3A%22binary%22%2C%22linkTarget%22%3A%22_blank%22%2C%22from%22%3A%22url%22%2C%22originWidth%22%3A750%2C%22originHeight%22%3A752%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%22JdacR%22%2C%22margin%22%3A%7B%22top%22%3Atrue%2C%22bottom%22%3Atrue%7D%7D" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"></card></p><p data-lake-id="uac6f955d" id="uac6f955d" style="text-align: center"><span data-lake-id="ue8c22650" id="ue8c22650" class="lake-fontsize-11" style="color: rgb(136, 136, 136)">img</span></p><h3 data-lake-id="FHHZH" id="FHHZH" style="text-align: left"><span data-lake-id="ua6a33f15" id="ua6a33f15" style="color: rgb(63, 63, 63)">OAuth 网络钓鱼和设备注册服务</span></h3><p data-lake-id="uedfe5cb9" id="uedfe5cb9" style="text-align: justify"><span data-lake-id="u02102154" id="u02102154" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">与其他 OAuth 网络钓鱼技术类似，本次攻击中的技术涉及与受害者的直接互动，要求他们点击链接并将代码返回给攻击者。攻击者随后利用该代码非法访问 M365 资源。</span></p><h4 data-lake-id="bnAnU" id="bnAnU" style="text-align: left"><span data-lake-id="ua6c50cf1" id="ua6c50cf1" style="color: rgb(15, 76, 129)">受害者互动</span></h4><p data-lake-id="ue7a873cd" id="ue7a873cd" style="text-align: justify"><span data-lake-id="u9ef14e5c" id="u9ef14e5c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">如果受害者回应了 UTA0355 通过 Signal 或 WhatsApp 发送的消息，他们将收到一个 M365 登录 URL 进行点击；该 URL 格式如下所示：</span></p><p data-lake-id="ub83b6b2a" id="ub83b6b2a" style="text-align: left"><span data-lake-id="u8c007def" id="u8c007def" class="lake-fontsize-11" style="color: rgb(10, 10, 10)">https://login.microsoftonline.com/common/oauth2/authorize?url=https://teams.microsoft.com/[redacted]&amp;client_id=29d9ed98-a469-4536-ade2-f981bc1d605e&amp;resource=01cb2876-7ebd-4aa4-9cc9-d28bd4d359a9&amp;response_type=code&amp;redirect_uri=https%3A%2F%2Flogin.microsoftonline.com%2FWebApp%2FCloudDomainJoin%2F8&amp;amr_values=ngcmfa&amp;login_hint=&lt;email@address.here&gt;</span></p><p data-lake-id="u90c5cd19" id="u90c5cd19" style="text-align: justify"><span data-lake-id="ubfa56c91" id="ubfa56c91" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">在受害者通过共享的 Microsoft URL 登录后，他们将被重定向到一个新的 URL，该 URL 中包含 OAuth 授权码。攻击者还附上了额外的说明，指示受害者在重定向发生后应分享他们在地址栏中看到的 URL。受害者浏览器生成并随后返回给 UTA0355 的 URL 格式如下：</span></p><p data-lake-id="u8212e59e" id="u8212e59e" style="text-align: left"><span data-lake-id="u9ab70418" id="u9ab70418" class="lake-fontsize-11" style="color: rgb(10, 10, 10)">https://login.microsoftonline.com/WebApp/CloudDomainJoin/8?code=[redacted]&amp;session_state=[redacted]</span></p><p data-lake-id="u19c17e62" id="u19c17e62" style="text-align: justify"><span data-lake-id="u8c02a4fc" id="u8c02a4fc" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">通过与攻击者共享此 URL，受害者在不知情的情况下将交出所有需要验证其身份的信息。这与之前观察到和怀疑的其他攻击活动类似。同样，这需要目标点击链接并返回一个代码或 URL。然而，受害者仅被要求与合法的 Microsoft 365 服务进行互动，而这些服务用户本能地可能会认为是可信的。此外，对于用户来说，从地址栏或合法的 Microsoft 网页上分享数据可能不会立即显得显而易见，因此可能会导致攻击者获得对其 M365 账户的访问权限。</span></p><h4 data-lake-id="VHCSb" id="VHCSb" style="text-align: left"><span data-lake-id="ud9fd15f4" id="ud9fd15f4" style="color: rgb(15, 76, 129)">UTA0355 OAuth 滥用</span></h4><p data-lake-id="ud1e802d6" id="ud1e802d6" style="text-align: justify"><span data-lake-id="u13c84206" id="u13c84206" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">受害者与攻击者共享的 URL 包含一个代码参数，内含 OAuth 授权码，该授权码将用于授予访问令牌。与之前的类似活动不同，初始登录请求的资源不是 Microsoft Graph API 的访问权限，而是设备注册服务。此服务被 Windows 用来将新设备加入到 Entra ID。攻击者将利用这一访问权限将名为</span><span data-lake-id="u12311e76" id="u12311e76" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u660f8b5e" id="u660f8b5e" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">DESKTOP-**[已编辑]**</span><span data-lake-id="u9dcbe14e" id="u9dcbe14e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u3438103a" id="u3438103a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">的新设备加入受害者的 Entra ID。Volexity 使用</span><span data-lake-id="ufc2cda82" id="ufc2cda82" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ud2f54dcf" id="ud2f54dcf" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">ROADTools 项目</span><span data-lake-id="u7aa73a0c" id="u7aa73a0c" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ue116cae4" id="ue116cae4" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">复制了这些步骤，并遵循了</span><span data-lake-id="u199d7103" id="u199d7103" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uc6fb3988" id="uc6fb3988" class="lake-fontsize-11" style="color: rgb(87, 107, 149)">这篇指南</span><span data-lake-id="u8b8f73f0" id="u8b8f73f0" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ua8ed4937" id="ua8ed4937" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">创建了一个新的令牌，该令牌具有完全权限访问 Microsoft Graph API。该技术利用了 Entra ID API 设计中的漏洞，授予了比最初授予的访问权限更高的访问令牌。</span></p><p data-lake-id="u3efdca24" id="u3efdca24" style="text-align: justify"><span data-lake-id="u6b2cfffa" id="u6b2cfffa" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">在初步互动发生后，并且 UTA0355 已经将其设备注册到受害者的 Microsoft Entra ID（Azure AD）中，Volexity 观察到与受害者的额外互动。在此互动中，UTA0355 请求受害者批准一个双因素认证（2FA）请求，“</span><em><span data-lake-id="ub48f2c50" id="ub48f2c50" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">以访问与会议相关的 SharePoint 实例</span></em><span data-lake-id="u712320ae" id="u712320ae" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">”。这是绕过受害者组织设置的额外安全要求，以便访问其电子邮件所必需的。</span></p><h3 data-lake-id="CBjE6" id="CBjE6" style="text-align: left"><span data-lake-id="u836f3255" id="u836f3255" style="color: rgb(63, 63, 63)">受害者妥协后的活动</span></h3><p data-lake-id="u09c38096" id="u09c38096" style="text-align: justify"><span data-lake-id="u17be5942" id="u17be5942" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">Volexity 高度确认，攻击者要求受害者批准 2FA 请求以访问电子邮件项目。在 Volexity 审查的日志中，初始设备注册在与攻击者互动后不久成功。第二天，UTA0355 设法让受害者批准其 2FA 请求，最终获得了访问电子邮件的权限。授权后，日志显示攻击者通过与新注册设备相关联的会话下载了目标的电子邮件。</span></p><p data-lake-id="u17953aad" id="u17953aad" style="text-align: justify"><span data-lake-id="u8e859c0e" id="u8e859c0e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">登录活动、电子邮件访问和设备注册都使用了一个代理网络的客户端 IP 地址，该地址的地理位置与受害者所在位置相同。</span></p><h2 data-lake-id="Jm5zy" id="Jm5zy" style="text-align: center"><span data-lake-id="u87cbbe7f" id="u87cbbe7f" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">检测相关活动</span></h2><p data-lake-id="u473c52f2" id="u473c52f2" style="text-align: justify"><span data-lake-id="u75c8997e" id="u75c8997e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">为了防止或检测这些攻击，Volexity 提出了以下建议：</span></p><p data-lake-id="u13a67d13" id="u13a67d13" style="text-align: justify"><span data-lake-id="uab536d28" id="uab536d28" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">1、考虑对 M365 登录活动进行警报，当 Visual Studio Code</span><span data-lake-id="ub29e18bb" id="ub29e18bb" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u0e4b9e3c" id="u0e4b9e3c" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">client_id</span><span data-lake-id="u00a49e38" id="u00a49e38" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ucc767c06" id="ucc767c06" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">值</span><span data-lake-id="u309b23c1" id="u309b23c1" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u71933bbe" id="u71933bbe" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">aebc6443-996d-45c2-90f0-388ff96faa5</span><span data-lake-id="u0007c4bb" id="u0007c4bb" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u44574285" id="u44574285" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">与包含“Microsoft Graph”的</span><span data-lake-id="ua3eb4bea" id="ua3eb4bea" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u7d7ef516" id="u7d7ef516" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">resourceDisplayName</span><span data-lake-id="uede567f1" id="uede567f1" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ua8d4882e" id="ua8d4882e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">一起使用时。根据你的环境和 Visual Studio Code 的使用情况，这可能是可行的，也可能不可行，因为合法用户也会使用该</span><span data-lake-id="ua1f2381e" id="ua1f2381e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u4711daaf" id="u4711daaf" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">client_id</span><span data-lake-id="uf103a972" id="uf103a972" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uaa7415c6" id="uaa7415c6" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">登录。</span></p><p data-lake-id="u2ee353a2" id="u2ee353a2" style="text-align: justify"><span data-lake-id="u2f274a59" id="u2f274a59" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">2、考虑对以下 URL 格式发出警报（无论是嵌入在电子邮件中还是代理日志中）。请注意，URL 中的参数可以以任何顺序出现，并且</span></p><p data-lake-id="u342f8bf2" id="u342f8bf2" style="text-align: left"><span data-lake-id="u5e56f77d" id="u5e56f77d" class="lake-fontsize-11" style="color: rgb(10, 10, 10)">redirect_uri</span></p><p data-lake-id="u11f32b36" id="u11f32b36" style="text-align: justify"><span data-lake-id="u32ba42ad" id="u32ba42ad" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">值必须设置为</span></p><p data-lake-id="u7ecb0365" id="u7ecb0365" style="text-align: left"><span data-lake-id="u431c372e" id="u431c372e" class="lake-fontsize-11" style="color: rgb(10, 10, 10)">insiders.vscode.dev/redirect</span></p><p data-lake-id="u05c82f22" id="u05c82f22" style="text-align: justify"><span data-lake-id="uac3b7374" id="uac3b7374" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">或</span></p><p data-lake-id="u23f77f0c" id="u23f77f0c" style="text-align: left"><span data-lake-id="ucd59ee82" id="ucd59ee82" class="lake-fontsize-11" style="color: rgb(10, 10, 10)">vscode-redirect.azurewebsites.net</span></p><p data-lake-id="u72fcbed2" id="u72fcbed2" style="text-align: justify"><span data-lake-id="ubb175f34" id="ubb175f34" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">示例 URL：</span></p><p data-lake-id="u85892e13" id="u85892e13" style="text-align: left"><span data-lake-id="u68178ff6" id="u68178ff6" class="lake-fontsize-11" style="color: rgb(10, 10, 10)">https://login.microsoftonline.com/organizations/oauth2/v2.0/authorize?state=[任何_url]&amp;client_id=aebc6443-996d-45c2-90f0-388ff96faa56&amp;scope=https://graph.microsoft.com/.default&amp;response_type=code&amp;login_hint=[电子邮件]&amp;redirect_uri=https://insiders.vscode.dev/redirect*</span><span data-lake-id="u1060d015" id="u1060d015" class="lake-fontsize-11" style="color: rgb(10, 10, 10)">https://login.microsoftonline[.]com/common/oauth2/authorize?redirect=[任何_url]&amp;client_id=aebc6443-996d-45c2-90f0-388ff96faa56&amp;resource=https://graph.microsoft.com&amp;response_type=code&amp;redirect_uri=https://vscode-redirect.azurewebsites.net&amp;login_hint=[电子邮件]&amp;ui_locales=en-US&amp;mkt=en-US&amp;client-request-id=[已移除]</span></p><p data-lake-id="ua7cae8a1" id="ua7cae8a1" style="text-align: justify"><span data-lake-id="u0d7c3240" id="u0d7c3240" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">3、评估阻止访问</span><span data-lake-id="ue5f15c62" id="ue5f15c62" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u7a68b46e" id="u7a68b46e" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">insiders.vscode[.]dev</span><span data-lake-id="ud7e27c9a" id="ud7e27c9a" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ude8ce04e" id="ude8ce04e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">和</span><span data-lake-id="u0e890743" id="u0e890743" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uf7ecfbea" id="uf7ecfbea" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">vscode-redirect.azurewebsites.net</span><span data-lake-id="uc53b7167" id="uc53b7167" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u157c7ecb" id="u157c7ecb" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">主机名的业务影响，并考虑实施这样的阻止措施。</span></p><p data-lake-id="u7fad6f38" id="u7fad6f38" style="text-align: justify"><span data-lake-id="ub6dc554e" id="ub6dc554e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">4、教育用户关于通过安全消息平台建立的新联系人所带来的风险。用户必须理解验证通过 Signal、WhatsApp 或其他安全消息平台联系的联系人的重要性。验证应该通过其他途径进行，而不是信任通过未经请求或意外联系提供的信息。</span></p><p data-lake-id="ue3b9a577" id="ue3b9a577" style="text-align: justify"><span data-lake-id="ufcbe40d0" id="ufcbe40d0" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">5、考虑寻找新注册的设备，并与注册的 IP 地址关联，查找低信誉或代理 IP 地址出现在</span></p><p data-lake-id="u86ea2906" id="u86ea2906" style="text-align: left"><span data-lake-id="u3316b84a" id="u3316b84a" class="lake-fontsize-11" style="color: rgb(10, 10, 10)">ClientIPAddress</span></p><p data-lake-id="uacad21d0" id="uacad21d0" style="text-align: justify"><span data-lake-id="ud7c2ff31" id="ud7c2ff31" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">字段中：</span></p><ul list="u5175f823"><li fid="u51c5246e" data-lake-id="u001b07b5" id="u001b07b5" style="text-align: left"><span data-lake-id="ua985c4c9" id="ua985c4c9" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 请注意，通过 Microsoft Graph API 持续访问用户电子邮件时，</span><span data-lake-id="ude872393" id="ude872393" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">ClientIPAddress</span><span data-lake-id="u23e556e1" id="u23e556e1" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u5abb1409" id="u5abb1409" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">字段不会包含攻击者的 IP 地址；相反，它包含的是 Microsoft 的 IP 地址。这种行为似乎没有文档记录，且与安全分析相悖。</span></li><li fid="u51c5246e" data-lake-id="u15667e9d" id="u15667e9d" style="text-align: left"><span data-lake-id="uc9a12fb5" id="uc9a12fb5" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 尽管攻击者活动不能轻易通过</span><span data-lake-id="u2295aabd" id="u2295aabd" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="ub10a81da" id="ub10a81da" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">ClientIPAddress</span><span data-lake-id="ue214b538" id="ue214b538" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u81c94e4f" id="u81c94e4f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">字段进行追踪，Volexity 通过与攻击者注册设备相关联的唯一 deviceId 值，成功追踪了攻击者活动。</span></li><li fid="u51c5246e" data-lake-id="u5d711a07" id="u5d711a07" style="text-align: left"><span data-lake-id="u5c7a316e" id="u5c7a316e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 持续访问的</span><span data-lake-id="u916d9bd4" id="u916d9bd4" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="uc2d9e38d" id="uc2d9e38d" class="lake-fontsize-10" style="color: rgb(221, 17, 68)">ClientAppID</span><span data-lake-id="u6b5a759b" id="u6b5a759b" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="u9e4fbf53" id="u9e4fbf53" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">字段可能与用户的典型电子邮件客户端不同，因为它将使用一个由攻击者创建的 AppID。</span></li></ul><p data-lake-id="u491af8d1" id="u491af8d1" style="text-align: justify"><span data-lake-id="u11d0117e" id="u11d0117e" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">6、考虑实施条件访问策略，仅允许已批准或已管理的设备访问组织资源。这可以有效防止设备注册和未经授权访问其他资源，例如电子邮件。</span></p><ul list="u1322c930"><li fid="u59dee043" data-lake-id="u812db59b" id="u812db59b" style="text-align: left"><span data-lake-id="u3c4a6e72" id="u3c4a6e72" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 截至发布时，Volexity 尚未发现通过条件访问策略阻止特定 Microsoft 第一方应用程序的方法。条件访问可以用于阻止对所有服务的访问，针对不符合要求的设备；然而，在短时间内对组织实施这一策略可能会面临挑战。</span></li><li fid="u59dee043" data-lake-id="u441f5927" id="u441f5927" style="text-align: left"><span data-lake-id="ub03a6498" id="ub03a6498" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">• 还应注意，Microsoft Teams 是 Volexity 观察到的 UTA0352 目标之一。对于大多数组织来说，阻止这一点可能不现实或不可行，即使可能也不太可能。</span></li></ul><h2 data-lake-id="STA5H" id="STA5H" style="text-align: center"><span data-lake-id="u6b65a05d" id="u6b65a05d" style="color: rgb(255, 255, 255); background-color: rgb(15, 76, 129)">结论</span></h2><p data-lake-id="u56b80ecc" id="u56b80ecc" style="text-align: justify"><span data-lake-id="u909ddf2d" id="u909ddf2d" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">动机驱动的威胁行为者将持续寻找新的方法来规避安全控制，并使用不为用户或网络防御团队所熟知的新方法来访问资源。这一系列攻击是自 2025 年 1 月以来，俄罗斯威胁行为者第二次通过鲜为人知的技术来获取 M365 资源。Volexity 推测，针对非政府组织、智库和人权捍卫者的这些攻击可能会加强，以利用这些个人和组织当前面临的预算削减和人员减少的局面。</span></p><p data-lake-id="u4a171529" id="u4a171529" style="text-align: justify"><span data-lake-id="u971aa8b0" id="u971aa8b0" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">与 Volexity 在 2025 年 2 月报告的</span><span data-lake-id="uce731e6f" id="uce731e6f" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><strong><span data-lake-id="uc29e55ae" id="uc29e55ae" class="lake-fontsize-11" style="color: rgb(15, 76, 129)">设备代码认证钓鱼活动</span></strong><span data-lake-id="u1d52b5cf" id="u1d52b5cf" class="lake-fontsize-11" style="color: rgb(63, 63, 63)"> </span><span data-lake-id="udb9a8014" id="udb9a8014" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">类似，这些最新的攻击活动依赖于所有用户互动都发生在 Microsoft 官方基础设施上；这些攻击没有使用攻击者托管的基础设施。同样，这些攻击也没有涉及恶意或攻击者控制的 OAuth 应用程序，用户无需明确授权访问（因此可以轻松被组织阻止）。使用已经获得授权的 Microsoft 第一方应用程序，使得这种技术的预防和检测变得相当困难。</span></p><p data-lake-id="u2d1d20e2" id="u2d1d20e2" style="text-align: justify"><span data-lake-id="u4cbe7835" id="u4cbe7835" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">组织应培训用户保持高度警惕，尤其是当收到通过安全消息应用的未经请求的联系时，特别是当要求用户点击链接或打开附件时。此外，为了使此特定类型的攻击成功，攻击者必须要求用户返回他们点击链接后的 URL 或代码。此策略通常不在用户的安全意识培训中，应该纳入组织的用户安全意识培训。</span></p><p data-lake-id="u08b6e286" id="u08b6e286" style="text-align: justify"><span data-lake-id="u0291a5d6" id="u0291a5d6" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">目前，Volexity 注意到，非政府组织、人权相关组织、提供援助和人道主义援助的组织以及与乌克兰相关的组织，可能是这些攻击活动最容易受到威胁的目标。尽管这种威胁活动目前只在有限的目标攻击中进行，但 Volexity 预计这种攻击方法会继续存在，并可能变得更加广泛。因此，组织应广泛警告用户这种类型的攻击。</span></p><p data-lake-id="ucee96385" id="ucee96385" style="text-align: justify"><span data-lake-id="u45c4c322" id="u45c4c322" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">最后，所有与 UTA0352 和 UTA0355 相关的消息都以乌克兰为主题，目标是众多曾经被俄罗斯威胁行为者攻击的个人和组织。基于此，并且考虑到 2025 年 2 月观察到的相似战术，Volexity 中等信心地评估，UTA0352 和 UTA0355 是俄罗斯威胁行为者。目前尚不清楚他们是否协同工作，或是否与 Volexity 之前的报告有所重叠。</span></p><p data-lake-id="u090bfb2a" id="u090bfb2a" style="text-align: justify"><span data-lake-id="u863f2dbb" id="u863f2dbb" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">​</span><br></p><p data-lake-id="uef0d1a28" id="uef0d1a28" style="text-align: justify"><span data-lake-id="ude5217e7" id="ude5217e7" class="lake-fontsize-11" style="color: rgb(63, 63, 63)">原文：https://www.volexity.com/blog/2025/04/22/phishing-for-codes-russian-threat-actors-target-microsoft-365-oauth-workflows/</span></p><p data-lake-id="uc686adbe" id="uc686adbe"><span data-lake-id="u7469338d" id="u7469338d" class="lake-fontsize-9" style="color: rgb(10, 10, 10)">​</span><br></p>
小瑟斯
发表于 7个月前
评论列表
加载数据中...
sechacker
发表于 7个月前
评论列表
加载数据中...