转载

SWIFT之殇

——针对越南先锋银行的黑客攻击技术初探

360追日团队

近期,孟加拉国、厄瓜多尔、越南、菲律宾等多个国家的银行陆续曝出曾经遭遇黑客攻击并试图窃取金钱事件,这些事件中黑客都瞄准了SWIFT银行间转账系统,对相关银行实施攻击和窃取。360追日团队深入分析了截获的黑客攻击越南先锋银行所使用的恶意代码样本,并由此对此次事件中的黑客攻击技术进行了初步探索。

一、概述

随着孟加拉国央行被黑客攻击导致8100万美元被窃取的事件逐渐升温,针对银行SWIFT系统的其他网络攻击事件逐一被公开,具体如下表所示:

攻击时间

被攻击银行

计划窃取

实际损失

2013年

索纳莉银行(Sonali Bank)

未知

25万美元

2015年1月

厄瓜多尔银行(Banco del Austro)

未知

1200万美元

2015年10月

疑似菲律宾某银行

未知

未知

2015年12月8日

越南先锋银行(Tien Phong Bank)

120万欧元

2016年2月5日

孟加拉国央行(Bangladesh   Central Bank)

10亿美元

8100万美元

未知

疑似香港某银行

未知

未知

未知

疑似菲律宾、新西兰某银行和其他10多家金融机构

未知

未知

表 1针对银行攻击事件汇总

通过对相关恶意代码和攻击手法的研究,以及其他安全厂商的研究结论,360追日团队推测针对孟加拉国央行和越南先锋银行发起攻击的幕后组织或许是同一个组织,该组织可能是Operation Blockbuster所揭秘披露的Lazarus组织,中国相关机构也是该组织主要攻击目标之一。

本报告主要就越南先锋银行的相关攻击事件、样本展开深入分析,暂不深入关联孟加拉国央行被攻击事件和Lazarus组织,对相关事件或组织之间的关联归属分析等,我们在之后的关联分析报告中会有详细的介绍。

关于Lazarus黑客组织

2016年2月25日,Lazarus黑客组织以及相关攻击行动由卡巴斯基实验室、AlienVault实验室和Novetta等安全企业协作分析并揭露。2013年针对韩国金融机构和媒体公司的DarkSeoul攻击行动和2014年针对索尼影视娱乐公司(Sony Pictures Entertainment,SPE)攻击的幕后组织都是Lazarus组织。

相关时间节点

具体事件描述

2007.03.07

“Flame”行动中第一代恶意软件开发完成,该活动最终与“1Mission”行动、“Troy”行动、2013年DarkSeoul攻击联系在一起。

2009.07.04

使用恶意工具MYDOOM、Dozer对美国、韩国网站发动大规模DDOS攻击,该恶意软件在MBR写入文本信息“Memory of Independence Day”。

2009-2013

“Troy”网络间谍行动活跃数年,在2013年DarkSeoul攻击达到顶峰。

2011.03

“Ten Days of Rain”行动攻击韩国媒体、金融、基础设施。利用韩国地区的肉鸡发动DDOS攻击。

2011.04

韩国农协银行被DDOS攻击。

2012

发动“1Mission”行动,该行动的攻击者被报道称从2007年就开始活跃。

2012.06

韩国保守媒体报纸声称受到具有清除功能的恶意软件的攻击,但未成功。网站被未知黑客团体“IsOne”篡改。

2013.03.20

DarkSeoul清除行动攻击韩国广播公司、金融机构、及一家ISP。两个未知黑客团队NewRomanic Cyber Army Team 和 WhoIs Team声称对此负责。

2014.03

疑似有黑客试图窃取韩国军方数据,使用的服务器之一也被用于DarkSeoul攻击。

2014.11.24

索尼影视娱乐公司网络被植入破坏性恶意软件,信息被窃取。早前的未知黑客组织GOP声称负责。

表 2 Lazarus组织历史活动相关重大事件节点

二、关于SWIFT

SWIFT全称是Society for Worldwide Interbank Financial Telecommunication,中文名是“环球同业银行金融电信协会”。1973年5月,由美国、加拿大和欧洲的—些大银行正式成立SWIFT组织,其总部设在比利时的布鲁塞尔,它是为了解决各国金融通信不能适应国际间支付清算的快速增长而设立的非盈利性组织,负责设计、建立和管理SWIFT国际网络,以便在该组织成员间进行国际金融信息的传输和确定路由。

目前全球大多数国家大多数银行已使用SWIFT系统。SWIFT的使用,使银行的结算提供了安全、可靠、快捷、标准化、自动化的通讯业务,从而大大提高了银行的结算速度。由于SWIFT的格式具有标准化,目前信用证的格式主要都是用SWIFT电文。

1.SWIFT提供的服务

l接入服务(Connectivity)

包括SWIFTAlliance Access and Entry 、SWIFTAlliance Gateway 、SWIFTAlliance Webstation 、File Transfer Interface 等接入模式;

l金融信息传送服务(Messaging)

包括SWIFTNet FIN 、SWIFTNet InterAct 、SWIFT FileAct 、SWIFTNeBrowse 等传输模式;

l交易处理服务(transaction processing)

提供交易处理匹配服务 、实时报告的双边净额清算服务 、支持B2B的商务中的端对端电子支付等;

l分析服务与分析工具(Analytical Services/Tools)

向金融机构提供一些辅助性的服务,即分析服务与分析工具。 

2.SWIFT CODE

SWIFT Code是由该协会提出并被ISO通过的银行识别代码,其原名是BIC (Bank Identifier Code)。

每个申请加入SWIFT组织的银行都必须事先按照SWIFT组织的统一规则,制定出本行SWIFT地址代码,经SWIFT组织批准后正式生效。SWIFT Code由8位或11位英文字母或数字组成。

代码格式:

l8码长—XXXXXXXX

a

b

c

X

X

X

X

X

X

X

X

l11码长—XXXXXXXXXXX

a

b

c

d

X

X

X

X

X

X

X

X

X

X

X

各部分的含义如下:

a. 银行代码:由四位易于识别的银行行名字头缩写字母构成,如 ABOC、ICBK、CITI 等;

b. 国家代码:根据国际标准化组织的规定由两位字母构成,如 CN、HK、GB、US、DE 等;

c. 地区代码:由两位数字或字母构成,标明城市,如 BJ、HH、SX 等;

d. 分行代码:由三位数字或字母构成,标明分行,如 100、010、CJ1、400 等,若表      示总行,则使用XXX。

3.SWIFT报文

SWIFT组织根据国际结算业务开展的需要,制定了相关的标准格式的报文,SWIFT的标准格式分为两种:

l基于FIN的标准MTs

l基于XML的新标准MXs

MTs(Message Type ,MTs通用表达式为MTnXX):n(0~9)表示报文类型,XX表示在n类型中的分类,目前共有10类报文,应用较多的是第1、2、3、5、7、9类型。

MXs :在1999年,SWIFT组织选择了XML编码作为新一代标准,同时决定最终应用新一代以XML为基础的标准(MXs), 目前两种标准共存,MX标准由12类报文组成。

SWIFT MT报文

根据银行的实际运作,SWIFT MT报文共划分为十大类:

名称

是否加密押

1

客户汇款与支票(CUSTOMER TRANSFERS CHEQUES)

加押

2

银行头寸调拔(FINANCIAL   INSTITUTION TRANSFERS)

加押

3

外汇买卖与存放款(FOREIGN EXCHANGE)

加押

4

托收(COLLECTIONS,CASH LETTERS)

加押

5

证券(SECURITIES)

加押

6

贵金属和辛迪加(PRECIOUS   METALS AND SYNDICATIONS)

加押

7

跟单信用证和保函(DOCUMENTARY CREDITS AND GUARANTEES)

加押

8

旅行支票(TRAVELLER’S   CHEQUES)

加押

9

银行帐务(BANK STATEMENT)

不加押

0

SWIFT系统报文

不加押

表 3 SWFIT MT报文十大类

SWIFT报文第1类至第8类均为押类电报,需要使用SWIFT密押。SWIFT密押是独立于电传密押之外,在代理行之间交换,且仅供双方在收发SWIFT电讯时使用的密押。其他两类属于不加押报文。

4.MT950对帐单

MT950范围

这是由帐户行发送给开户行,用来说明所开帐户上所有发生额详细情况的报文格式。

SWIFT之殇

MT950准则

l费用、利息及其它调整所应用的方式

1.列明已发送的费用通知MTn90报文编号;

2.如该费用系通过本对帐单首先通知开户行,则必须符合以下条件:

① 必须用相关业务编号加以识别,如开户行原业务的编号;

② 本金必须在对帐单中单独列明。

l对帐单中的金额必须与原业务中的金额一致。如有费用已在业务报文中清楚列明,或是

某一报文的必要组成部分(如托收款项),则该费用不必在对帐单中特别注明;

l帐户行不得将各自独立的业务并笔。如原收付报文系多笔业务,对帐单中仍应分别记帐,每笔借记均须引用原各自报文中域20;

l建议在每个营业日日终,只要帐户中有发生额,帐户行就发送MT950;

l为便于人工核对,建议对帐单中的发生额先按借记和贷记排列,在借记和贷记两类中分别按起息日排列,同一起息日的借、贷记中,按金额由小到大排列;

l一份对帐单的内容可由数份报文组成。

MT950域详述

l域 20:发报行的编号

l域 25:帐号

列明该对帐单的帐号。

l域28C:对帐单号码 / 分页序号

该域内容前后分别表示对帐单连续号码和每一份对帐单报文的分页序号。

l域60a:起始余额

列明某对帐单所涉及的一段时期开始时,有关帐户的帐面余额;或当报文出现分页时,每一分页的过渡起始余额。其内容包括:

借贷标志         D:借方余额           C:贷方余额

日期                   用YYMMDD表示

货币

金额

该域内容必须与前一份该帐户对帐单报文域“62a”相同。只有当该报文系某一时期对帐单的第一分页,或对帐单没有分页,这份报文中该域代号才为“60F”。

l域61:对帐单细目

列明每笔业务的详情。在报文的容量允许范围内,该域可重复使用,其内容共有九个子域,顺序如下:

起息日用                                               YYMMDD表示

记帐日期(可省略)                       用MMDD表示

借贷标志                                               D:借记C:贷记RC:以借冲贷RD:以贷冲借

货币代号(在需要时使用)         填入货币符号的第三个字母

金额

业务类型                                               其出现方式有以下三种:

1.如系通过SWIFT报文收付的金额及其费用,其类型表现为:“Snnn”字母“S”后的三位数字即SWIFT报文格式代号。

2.如系通过非SWIFT报文收付的金额及其费用,其类型表现为“Nxxx”字母“N”后的三个字母为下列代码之一所替换以表示该资金收付的理由:

BOE

汇票

DIV

股利

BRF

纪经人佣金

EQA

等值金额

CHG

有关费用

ECK

欧洲支票

CHK

支票

FEX

外汇买卖

CLR

光票信用及票汇

INT

利息

CMI

资金管理

LBX

专用信箱

CMN

资金管理

LDP

贷款保证金

CMS

资金管理

MSC

杂项

CMT

资金管理

RTI

还款

CMZ

资金管理

SEC

证券(记入本金时使用)

COL

托收

STO

长期订单

COM

佣金

TCK

旅行支票

DCR

跟单信用证

TRF

头寸调拨

DDT

直接借记

VDA

调整起息日

3.由本对帐单首次通知开户人的收付金额(该收付发生在帐户行,在发送本对帐单之前未曾通知过开户人),其类型表现为:“Fxxx”。字母“F”后的三个字母必须为适当的代码以表示该借记或贷记的原由(代码同2)。

供开户行参考的编号       

该子域内至少应出现一个有效字符

帐户行的编号(需要时使用)

列明帐户行有关业务的编号。如某业务发生在帐户行,那么帐户行的编号应和第七个子域中的编号一致,在这种情形下,该子域可以不用。

补充内容

填写业务的详细情况

l域62a:帐面余额(结束余额)

如对帐单没有分页,或某报文是对帐单的最后一个分页(在对帐单由数份报文组成时),在这样的报文中,该域代号为“62F”,其内容为该对帐单结束时的帐面结存的最后余额,其余额必须出现在下期对帐单的域“60F”中。如该报文不是对帐单的最后一个分页,该域代号为“62M”,其内容为过渡帐面余额,其余额必须出现在下一分页的“60M”中。其内容有四个子域,结构同域“60a”。

l域64:有效余额

如该域列明贷方余额,则为有效余额。如列明借方余额,则开户人须为此支付利息。其内容有四个子域,结构同域“60a”。

三、攻击事件分析

1.整体流程

SWIFT之殇

图 1整体关系流程

针对越南先锋银行的攻击中,相关恶意代码内置了8家银行的SWIFT CODE,越南银行均在这些银行中设有代理帐户。目前看到的Fake PDF Reader样本目的不是攻击列表中的这些银行,而是用来删除越南银行与其他家银行间的转帐确认(篡改MT950对帐单)。这样银行的监测系统就不会发现这种不当交易了。

2.功能概述

Fake PDF Reader伪装成Foxit reader(福昕PDF阅读器),原始Foxit Reader.exe被重命名为Foxlt Reader.exe,在银行系统调用Foxit打印pdf时激活,将pdf转换为xml,根据配置文件匹配是否有符合要求的报文,找到匹配的报文修改后转换回pdf并调用原始的FoxitReader打印。并删除临时文件和数据库的符合条件的交易记录。

SWIFT之殇

图 2关系图

SWIFT之殇

图 3配置文件格式

3.案例:MT950对帐单(PDF)详解

SWIFT之殇

图 18 MT950对帐单(PDF)

上图是MT950对帐单的PDF版本,图中就对帐单的关键报文域进行了对应的解释(黑体字所示),另外蓝色框是Fake PDF Reader恶意程序需要判断和修改的地方(蓝色字体是相关具体动作的说明)。

下图是正常的PDF对帐单和篡改后的PDF对帐单,其中左图红色底色部分内容,就是攻击者想要删掉帐单记录和需要修改的帐面余额和有效余额。

SWIFT之殇

图 19正常PDF对帐单(左图),篡改后的PDF对帐单(右图)

4.技术细节

Fake PDF Reader分析

MD5

0b9bf941e2539eaa34756a9e2c0d5343

文件大小

1,327,104字节

图标

SWIFT之殇

编译器

Microsoft   Visual C++ 6.0

SWIFT之殇

图 4功能流程图

Fake PDF Reader程序来自于Foxit PDF SDK,依赖动态库fpdfsdk.dll。

A、读取配置文件

配置文件使用异或加密,KEY为7C4D5978h。路径为 c:/windows/temp/WRTU/LMutilps32.dat。

SWIFT之殇

图 5读取配置文件

B、处理参数

参数个数必须大于等于4个,应该为:“FoxitReader路径”、“/t”、“pdf路径”和“打印机ip”。

C、PDF修改

SWIFT之殇

图 6 PDF修改执行流程

lPDF转XML:以参数-xml调用了pdf2html库,转换成xml,文件放在临时目录。

SWIFT之殇

图 7 PDF转XML

l读取xml文件:查找Instance Type and Transmission所在的行,跳过9行,匹配SWIFT消息类型字符串,有FIN 950则进入950消息处理,没有则进入非950消息处理。

l950消息处理:匹配Sender字段,查找发报方的SWIFT Code,匹配是否在列表中。符合条件则定位Opening Balance行,并跳过9行,读取Amount数值,转换为Int64。继续跳过2行,匹配是否为Debit,循环读取Opening Balance的所有交易和配置文件中的字符串比较,符合则设置删除标记并对数据做累加操作,继续读取Closing Balance节中的Amount字段,转换为Int64。根据前面累加的数据和此数据对比,平帐后写入数据并设置Debit/Credit标记。完成修改后,新添加1页,重新添加所有行,并删除前面的1页。

SWIFT之殇

图 8恶意代码内部预设的SWIFT CODE

SWIFT   CODE

银行名称

国家

城市

UOVBSGSG

大华银行有限公司

新加坡

ANZBAU3M

澳大利亚和新西兰银行集团有限公司

澳大利亚

墨尔本

BOTKJPJT

三菱东京银行有限公司

日本

东京

MHCBJPJT

瑞穗银行

日本

东京

CZNBKRSE

国民银行

韩国

首尔

*******N

中国某银行境外分行1

越南

河内

UNCRITMM

联合信贷银行

意大利

米兰

*******3

中国某银行境外分行2

美国

纽约

表 4恶意代码内部预设的SWIFT CODE对应的具体银行名称

l非950消息处理:从Sender行开始读取,和配置文件匹配,成功后删除整页。

l修复xml中的行的坐标,修复指定行的字体,并修正Closing Avail Bal (Avail Funds)的值。

l删除临时文件。

SWIFT之殇

图 9删除临时文件

lXML转PDF。

D、使用原参数调用真正的FoxitReader.exe

SWIFT之殇

图 10调用真正的FoxitReader

E、失败则调用LogClear

SWIFT之殇

图 11调用LogClear

F、最后删除临时文件

LogClear分析

MD5

909e1b840909522fe6ba3d4dfd197d93

文件大小

20,480字节

编译器

Microsoft Visual C++ 6.0

SWIFT之殇

图 12功能流程图

根据传入参数个数进行相关初始化操作,如果有进行初始化操作,如果没有参数则直接开始执行清除操作;

命令参数格式:'-f <message filename> -l <logfile path>'

SWIFT之殇

图 13相关参数格式

进一步进行循环删除文件中记录的内容,根据参数格式化一个文件名称,进行删除消息文件相关记录操作。

文件名格式:%s//%s_%d%.2d%.2d.txt,第一个%s是从配置文件中读取的路径,第二个%s的字符串内容如下,后面的%d依次表示年、月、日。

SWIFT之殇

图 14读取的相关内容

SWIFT   CODE

银行名称

国家

城市

TPBVVNVX

越南先锋银行

越南

最后通过sqlcmd.exe 执行数据库操作删除数据库中消息文件相关记录.

SWIFT之殇

图 15清理错误日志1

SWIFT之殇

图 16清理错误日志2

SWIFT之殇

图 17清理graft_history

同源性分析

在本报告中主要就越南先锋银行相关攻击事件、样本展开深入分析,暂不就其他攻击事件中的同源样本展开详细介绍,本节只简单证明二者之间的存在一定的联系。

关于越南先锋银行、孟加拉国央行和Lazarus组织之间的关系,我们在之后的关联分析报告中会有详细的介绍。

针对目标

越南先锋银行

孟加拉国央行

MD5

0b9bf941e2539eaa34756a9e2c0d5343

24d76abbc0a10e4c977a28b33c879248

安全删除函数

SWIFT之殇

SWIFT之殇

四、总结

从将恶意程序构造伪装成Foxit reader(福昕PDF阅读器)到对MT950对帐单PDF文件的解析和精确的篡改等攻击手法,都反映出攻击者对银行内部交易系统和作业流程非常熟悉。

针对越南先锋银行的针对性攻击和之前针对孟加拉国央行等其他银行的攻击之间,并非独立无关的攻击事件,从360追日团队对相关样本同源性分析和其他厂商的研究分析来看,针对越南先锋银行和孟加拉国央行的攻击有可能来自同一个组织,其幕后组织有可能是Operation Blockbuster所揭秘披露的Lazarus组织。

本文由 360安全播报 原创发布,如需转载请注明来源及本文地址。本文地址:http://bobao.360.cn/learning/detail/2890.html

原文  http://bobao.360.cn/learning/detail/2890.html
正文到此结束
Loading...