关键词
语音钓鱼
Vishing 即语音钓鱼,是网路钓鱼 ( Phishing ) 的电话版本。黑客们利用语音钓鱼的方式 , 在短短的几分钟内就可清空人们的账户。近年来,随着 Vishing 的兴起,人们便不再信任未知号码呼叫。
比如,接到冒充银行员工的联系人打来的电话是非常令人讨厌的,最近研究人员遇到了一组以前从未见过的恶意应用程序,开发者将其称为 "Letscall",目前针对的是来自韩国的个人用户。从技术上讲,没有任何规定禁止他们将攻击范围扩大到欧盟国家。换句话说,我们正在处理一个随时可用的框架,任何攻击者都可以使用它,因为它包含了关于如何操作受影响设备以及如何与受害者沟通的所有说明和工具。
该组织可能包括:
熟悉现代 VOIP 流量路由概念的 Android 开发人员,我们称其为 " 开发人员 ",因为我们在其中一个阶段观察到命令命名的差异。
设计人员负责网页、图标以及管理面板、网络钓鱼网页和移动恶意应用程序的内容。
前端开发人员熟悉 JavaScript 开发,包括 VOIP 流量处理。
后端开发人员熟悉保护后端 API 免受未经授权访问的技术。
呼叫具有语音社会工程攻击技能的接线员,他们可以流利地说不同的语言。
攻击分为三个阶段:
受害者访问一个特别制作的钓鱼网页,看起来像 Google Play Store。受害者从该页面下载恶意应用程序链的第一阶段。
第一阶段(我们称之为下载程序)在设备上运行准备工作,获得必要的权限,打开钓鱼网页,并安装第二阶段恶意软件,该恶意软件将从控制服务器下载。
第二阶段是一个强大的间谍软件应用程序,它将帮助攻击者窃取数据,并将受攻击的设备注册到 P2P VOIP 网络中,该网络用于通过视频或语音通话与受害者通信。此应用程序还会释放第三个阶段,即链的下一个部分。
letcall 使用 WEBRTC 技术来路由 VOIP 流量,并将受害者与呼叫中心操作员连接起来。为了达到最大的电话或视频通话质量,并克服 NAT 和防火墙,Letscall 使用 STUN/TURN 方法,包括 Google STUN 服务器。
第三阶段是第二阶段恶意软件的配套应用程序,并扩展了一些功能,它包含电话呼叫功能,用于将呼叫从受害者设备重定向到攻击者呼叫中心。
Vishing 技术迭代过程
这种钓鱼攻击已经发展得非常先进和复杂了,因为欺诈者现在使用现代技术进行语音通信路由和自动呼叫受害者的系统(所谓的自动窃取者,用于通过电话自动广告),并播放预先录制的诱惑信息。如果受害者上钩了,接线员就会接起电话,引导受害者按照骗子的要求行事。攻击者可能会欺骗受害者到最近的自动取款机取现金,或者迫使受害者披露个人信息,如银行账户数据、信用卡详细信息或银行凭证。
在过去的几年里,这种攻击已经成为一种明显的趋势,没有证据表明欺诈者会放弃该方法。
如今,受害者和安全行业都在发展,并通过各种防御机制对抗这种攻击。使用呼叫者识别应用程序或了解欺诈者策略可能足以抵御攻击者。
这可能是欺诈者试图利用他们所掌握的任何类型的信息,而不仅仅是使用姓名和电话号码来获得受害者信任的原因之一。为了获得更高级别的信任,攻击者通过访问受害者设备对受害者进行侦察。
将这两种类型的攻击 ( 手机攻击和 Vishing ) 结合起来,欺诈者可以 " 一举两得 ":我们观察到的一种常见攻击类型包括在请求受害者小额贷款。如果受害者注意到一些不寻常的活动,攻击者将打电话给受害者,冒充银行安全小组的成员,并向受害者保证没有什么可担心的。
在完全控制受攻击设备的情况下,攻击者还会将任何呼叫重新路由到由攻击者管理的另一个呼叫中心。如果受害者决定联系银行并询问与可疑活动有关的问题,准备充分的接线员将接听电话。使用这种作案手法,攻击者还可能要求受害者提供更多细节,以帮助他们进行犯罪活动并完成资金转移。
这种攻击是非常危险的,因为受害者必须偿还贷款,金融机构可能不会关心这种攻击和设备攻击,从而降低了调查潜在欺诈攻击的可能性。这就是为什么这样的攻击应该被业界披露和报告的原因。
对于 "letcall" 恶意软件的所有三个阶段,攻击者都使用了强大的逃避检测技术。一些版本的下载程序使用腾讯 Legu 模糊处理或 Bangcle(SecShell)进行了保护。对于第二和第三阶段,使用了 ZIP 文件目录树中的长名称和清单攻击技术。Checkpoint 最近也报道了同样的技术。然而,从代码和基础设施的角度来看,这些活动是不同的。攻击者有可能彼此分享知识,或者受到同一地区其他攻击者的影响。
"Letscall" 第二和第三阶段规模巨大,我们的研究仍在进行中。然而,我们现在想提供一些见解。
下载程序
目前还不知道攻击者如何说服受害者访问可以找到下载程序的诱饵网页,这可能是一种黑化的 SEO 技术或使用垃圾邮件的社会工程。到目前为止,我们知道这些页面模仿了 Google Play store,并针对移动屏幕分辨率进行了优化。这里一个值得注意的细节是页面的语言为韩语。
从技术角度来看,使用的下载程序是相对简单的应用程序,有时使用我们稍后将描述的自定义技术。下载程序的目标是做两件事:下载并运行第二阶段应用程序。有效负载的 URL 地址被硬编码到应用程序中。
打开带有网络钓鱼窗口的 web 视图,该窗口也硬编码到应用程序中。
这些页面会因正在进行的传播活动而有所不同,研究人员发现至少有 3 个页面模仿了 Banksala(贷款比较聚合器)、Finda(贷款对比聚合器)和 KICS(韩国刑事司法服务信息系统)。
每个页面都会诱使受害者输入敏感信息,如居民注册号(身份证)、电话号码、家庭地址、工资大小和雇主姓名。该输入数据将自动发送给攻击者。同样的数据也被输入到贷款聚合器的原始网页中。我们可以非常肯定地说,攻击者要么会使用窃取的数据在合法网站上填写类似的表格来申请贷款,要么也可能是网络钓鱼页面在受害者和贷款聚合页面之间充当代理:
第二阶段
乍一看,这个应用程序显然是非常模糊的,要分析它的功能需要很长时间。让我们来看看其中的每一种技术:
1.APK 文件中包含长路径名。一些分析系统将无法处理提取此类 APK 文件的内容。
2.XML 文件攻击。
3. 代码打包:核心 DEX 文件不包含清单中列出的代码。然而,它包含模糊代码,这些代码将从 APK 收集文件,对其进行解密并加载。这些文件位于 APK 文件的根目录中,它们的名称以 "o" 开头,以 "bf" 结尾,即 "obf" 或模糊处理:
所有的文件都有相似的标题和相对较低的熵。
甚至还隐藏了一些字符串:
经过一些修改之后,很明显,这几十个文件都是 DEX 文件,只是在它们的标头文件中做了微小的修改。通过观察文件第一个字节中重复的 0x1f 值,我们可以猜测,为了隐藏原始标头,使用了一个字节的异或加密,并且只加密了文件的 0x64 字节。
我们重建了 APK 文件并分析了代码。在第一步分析之后,我们意识到我们面临着一些重大问题。
由此产生的 APK 文件基于十几个不同的框架,包括 okhttp3 和 butterknife 等流行的框架,以及我们第一次观察到的一些库。
最有趣的库是 im/zego。
第二阶段滥用合法服务 ZEGOCLOUD 作为 IP 语音通信和消息传递的提供商。为了处理这种依赖于 WEB RTC 的通信,攻击者使用中继服务器。特别使用的公开可用的 STUN/TURN 服务器,包括来自 Google 的服务器,以及自配置的服务器。在此过程中,他们还窃取了应用程序代码中的凭据。
需要这样的功能来执行呼叫中心运营商和受害者之间的 P2P 语音 / 视频连接,并且相同的信道也用于具有许多不同命令的 C2 通信。此外,该恶意软件还支持使用网络套接字进行通信。来自 P2P 服务和 web 套接字通信的命令有时会相互重复,共涉及 32 个命令。
为了过滤数据并更改配置,恶意软件使用传统的 http 通信:
攻击者还可以对需要重定向的电话号码配置白名单,对需要绕过重定向的电话号码配置黑名单。
我们注意到的另一件有趣的事情是 nanoHTTPD 的使用,这个应用程序创建一个本地 http 服务器,然后打开 Chrome 浏览器进行访问。
通过滥用可访问性服务,它将把必要的界面元素推入 Chrome,并将第三阶段的恶意软件传递给受害者。这种更复杂的方法被用来以更有效的方式欺骗受害者。
第三阶段
从技术角度来看,安装的下一个 APK 文件看起来与第二阶段 APK 非常相似,使用了相同的逃避检测技术,并且相同的 xor 加密 DEX 文件位于 APK 文件的根文件夹中。此应用程序还包含一个大型代码库:
第三阶段最有趣的部分是名为 "phonecallapp" 的包,该包包含负责电话操纵攻击的代码,它将拦截传入和传出的呼叫,并根据攻击者的愿望重新路由。
为了配置处理电话呼叫的方式,攻击者使用具有以下结构的本地 SQLite 数据库:
在第三阶段 APK 的资产中,已经准备好了 MP3 语音信息,如果有人试图拨打银行电话,就会播放给受害者。
对于攻击者来说,他们的目标显然是模仿客户给银行打电话时的体验。
第三阶段有自己的一组命令,其中还包括 Web 套接字命令。
其中一些命令与地址簿的操作有关,例如创建和删除联系人。其他命令涉及创建、修改和删除过滤器,这些过滤器确定哪些调用应该被拦截,哪些应该被忽略。
基础设施
在我们获得 Downloader 之后,我们开始分析 C2 服务器并分析了管理面板。
与许多不同的 WEB 应用程序一样,它由两部分组成。
基于 VueJS 的前端,用于向攻击者提供可视化内容;
基于 Laravel PHP 框架的后端,使用 API 与前端和恶意应用程序通信;
前端是最有趣的部分,因为它为管理员和电话接线员提供了一个功能齐全的工作帐户。从这个面板中,电话接线员可以选择受害者,并直接从浏览器开始视频 / 音频对话。运营商还可以看到从目标泄漏并上传到基础设施的完整详细信息列表。它由至少 33000 个代码字符串组成。
我们确定了操作员可以使用的至少 19 个与受攻击设备控制相关的菜单:
此 JavaScript 应用程序将使用与两个阶段的应用程序相同的 VOIP 基础设施,这些服务器列在管理面板配置文件中:
值得注意的是,前端应用程序包含所谓的教程和演示。ThreatFabric 能够下载其中的两个。在这些视频中,我们可以观察到完整的攻击链以及它是如何在野外发生的。它们可能是为了方便电话接线员,从受害者的角度向他们展示攻击过程,并使他们能够回答受害者可能提出的问题。
在分析了前端面板之后,我们发现了后端的各种 API。攻击者将他们分为两大类:
Admin —负责管理操作员对管理面板的访问的 API,
sys-user —负责从后端基础设施检索数据并控制受感染设备的 API。
Admin 面板代码还显示了一些图片和音频文件,音频文件与我们在第三阶段应用程序中看到的相同。
另一方面,图片为我们提供了一些额外细节,例如可能支持四种语言:英语、韩语、日语和中文。
一些图片包含元信息,比如它们被创建的时间 ( 2022-12-02 15:22 ) 。此外,还提供了一个时区:+8。这个时区对应的是南亚国家,包括中国。
我们还观察了几个韩国金融机构的名称,这些名称将在攻击中被使用。
总结
在分析了 "letcall" 恶意软件活动后,研究人员确定这是一个熟悉 Android 安全和现代语音路由技术的网络犯罪组织。该组织证明,技术上精心设计的社会工程攻击仍然极其危险。该组织致力于使用虚假的 Google Play 页面,窃取现有韩国应用程序的图标,并结合使用 nanoHTTPD 的新技术来减少有效负载。
居民登记号码 ( 或身份证 ) 盗窃可以为网络攻击者攻击打开方便之门,我们看到,随着政府、私人和公共机构越来越多地采用电子身份证解决方案,这种攻击方式只会增加。重复使用其他攻击者使用的相同逃避检测技术在亚洲攻击组织中很常见。
从网络分析的角度来看,观察另一种控制僵尸网络并将流量隐藏在 WEB RTC 服务内部的方法是很有趣的。这突出了这样一个事实,即无论使用的是私人服务器还是谷歌 STUN 服务器,此类流量都应该始终由保护系统进行分析。
关于 "letcall" 应用程序,我们讨论了多功能间谍软件,该软件的设计密切关注与受害者的视频和音频连接,以及拦截短信和电话等通信。基于其代码中包含的许多不同特性,letcall 可以被归类为 RAT。RAT 允许攻击者了解受害者的所有信息,并执行有效的社会工程攻击。
最后,一些设计良好的基础设施可能会被讲不同语言的电话运营商使用。研究人员预测,这样的工具包可以作为 MaaS ( 恶意软件即服务 ) 在暗网上传播。
为了保证安全,我们需要拒绝任何可疑应用程序的访问 。
END
阅读推荐
安全圈
←扫码关注我们
网罗圈内热点 专注网络安全
实时资讯一手掌握!
好看你就分享 有用就点个赞
支持「安全圈」就点个三连吧!
推荐站内搜索:最好用的开发软件、免费开源系统、渗透测试工具云盘下载、最新渗透测试资料、最新黑客工具下载……
还没有评论,来说两句吧...