首页
社区
课程
招聘
[原创]HW在即——红队活动之Lnk样本载荷篇
发表于: 2020-7-30 18:01 3818

[原创]HW在即——红队活动之Lnk样本载荷篇

2020-7-30 18:01
3818

在日常的活动中,我们都可以看到LNK载荷的存在,从U盘蠕虫对U盘文件进行伪装,以达到欺骗受害人点击的目的,再到红队活动甚至于部分APT组织也使用了LNK文件作为其投递的主要载荷.LNK文件的载荷拥有自动隐藏.lnk后缀名,从而展现伪装的后缀名以欺骗目标的特点而被广泛使用,下面我们将先通过解析LNK文件格式进行切入,再通过其基础进行样本的相关构造,最后我们会介绍一些需要注意的地方.也希望各位看官如果在看到错误的地方可以在私信或者评论向笔者指出,笔者将感激不尽。

另外本样本不讨论相关的免杀性,免杀的操作请各位看官自己实现.

文件前20字节固定不变:

图片1 文件前20字节

HeaderSize(4 bytes, offset 0x00):0x0000004C

LinkCLSID(16 bytes, offset 0x04):00021401-0000-0000-C000-000000000046

offset 0x14起始4字节为LinkFlags(下图来自微软官方文档):

图片2 LinkFlags定义

由图片2可以看到,该文件LinkFlags0x000802DB(Bin:0000 0000 0000 1000 0000 0010 1101 1011),这表示以下Flag被设置:

上述Flag会在下文解释,故此处先不做展开。

offset 0x18起始4字节为FileAttributes0x00000020表示FILE_ATTRIBUTE_ARCHIVE

offset 0x1C开始,每个字段各占8字节:

图片3 Time

由图4可以看到,FileSize0x000E0400(占4个字节)。

IconIndex0x00000001(占4个字节)。

offset 0x3C开始,ShowCommand4字节,0x00000001表示SW_SHOWNORMAL,当然也可以根据具体的需要替换为SW_SHOWMAXIMIZED (0x00000003)(窗口最大化)以及SW_SHOWMINNOACTIVE (0x00000007)(窗口最小化)

Hotkey2字节;余下10个字节均为保留位。

由于LinkFlagsHasLinkTargetIDList设为1,故文件包含LinkTargetIDList结构。LinkTargetIDList构成如下:

图片5 LinkTargetIDList

IDListItemID构成,以2字节全为0TerminalID作为结束:

图片6 ItemID

下面来看示例文件中的LinkTargetIDList:

图片7 LinkTargetIDList示例

上图红色部分为IDListSize,绿色部分为TerminalID,中间蓝色部分则为IDList。下面来看IDList,第一个ItemID如下:

第二个ItemID

图片8 ItemID-2

第三个ItemID

图片9 ItemID-3

不再赘述,其含义为Windows。

第四个ItemID

图片10 ItemID-4

其含义为System32。

第五个ItemID

图片11 ItemID-5

由于LinkFlagsHasLinkInfo设为1,故文件包含LinkInfo结构。LinkInfo构成如下:

图片12 LinkInfo

下面来看下示例文件中的LinkInfo

图片13 LinkInfo示例

每个String Data结构如下:

图片14 String Data

由于LinkFlagsHasRelativePath设为1,故文件包含RELATIVE_PATH字符串:

图片15 RELATIVE_PATH

红色部分是CountCharacters(Unicode字符串长度,故应该为0x22*2=0x44),蓝色部分则为String

之后是WORKING_DIR字符串:

图片16 WORKING_DIR

ICON_LOCATION字符串:

图片17 ICON_LOCATION

由于LinkFlagsHasExpString设为1,故文件包含EnvironmentVariableDataBlock

图片18 EnvironmentVariableDataBlock

图片19 TargetAnsi

图片20 TargetUnicode

由零个或多个下列数据块与TERMINAL_BLOCK组成:

图片21 EXTRA_DATA

示例文件中的EXTRA_DATA包含SpecialFolderDataBlock

图片22 SpecialFolderDataBlock

KnownFolderDataBlock:

图片23 KnownFolderDataBlock

PropertyStoreDataBlock:

图片24 PropertyStoreDataBlock

PropertryStore(492 bytes)

TrackerDataBlock:

图片25 PropertyStoreDataBlock

我们首先生成一个正常的LNK文件:

图片26 正常LNK文件

之后更改其图标为%SystemRoot%/System32/SHELL32.dll中任意一个:

图片27 修改图标

010 Editor打开该LNK文件,找到String Data部分ICON_LOCATION字符串:

图片28 ICON_LOCATION

我们要将其修改为./1.pdf(Unicode),其长度0x07

图片29 修改图标

其效果如下所示(左边机器打开PDF文件的默认程序是XODO PDF Reader,中间是Adobe Reader,右边是谷歌浏览器):

图片30 效果展示

其会根据目标机器上所安装的环境进行适配,以显示出符合本机环境的图标,加大了样本的成功几率

原始目标如下所示:

图片31 原始目标

现在我们修改EnvironmentVariableDataBlock中的TargetAnsiTargetUnicode

图片32 修改TargetAnsi

图片33 修改TargetUnicode

将其修改为%windir%/system32目录不存在的一个EXE文件名。

效果展示:

图片34 效果展示

但这时双击该文件会报错:

图片35 报错

所以我们需要再修改LinkTargetIDList中第五个ItemID

图片36 修改第五个ItemID

如此一来,打开该文件便会弹出计算器:

图片37 弹出计算器

首先新建一指向%windir%/System32/mshta.exe的快捷方式(文件名尽量带有迷惑性),并更改其图标为%SystemRoot%/System32/SHELL32.dll中任意一个:

图片38 mshta

之后更改其参数为HTA下载地址:

图片39 文件下载

注:笔者是使用Cobalt Strike生成HTA文件:

于其执行payload前增加如下语句(用于下载诱饵文档并且进行打开,同时诱饵文档的显示有多种方法,这里只是举一个例子):

这样一来,在受害者打开LNK文件后会从远程下载一正常PDF文档并打开。

接下来按照0x02部分所述方法修改即可,此处加一个Tip——在其WORKING_DIR字符串前面添加大量空格字符,使其目标长度超过260个字符:

图片40 添加空格字符

使用copy /B命令将其与正常PDF文档捆绑,使其文件大小看起来更具有说服力:

图片41 文件大小

之后双击该LNK文件,主机便会上线,而受害者会看到一正常的PDF文档:

图片42 主机上线

效果展示:

图片43 效果

文中只是以pdf为后缀做了一个例子,看官在具体进行构造的时候可以使用其他的后缀,只要是后面以10 00 00 00结尾即可

图片44 不同后缀的情况

当然看官也可以通过修改前面的规定数据大小的值以实现不拘泥于数字与字母的命名方式

如上图中的docx所示其数据大小为9,数据值为.\11.docx而下面的png所显示的数据大小为7,数据值为.\1.png。经过反复的修改测试可得知,只要其数据值能够符合其前面规定的数据块其就可以正常解析并且显示.

本文属于抛砖引玉,其所使用的技术也不是很新颖.但的确可以在一定程度上起到迷惑的作用,故本绝影小组认为值得分享,同时鉴于有不少的APT组织(例如Gamaredon,Oceanlotus,SideWinder等)也同样进行lnk载荷的投递,希望各单位可以培养针对相关鱼叉载荷的安全意识,以减少损失.

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

[招生]科锐逆向工程师培训(2024年11月15日实地,远程教学同时开班, 第51期)

收藏
免费 2
支持
分享
最新回复 (1)
雪    币: 1821
活跃值: (1928)
能力值: ( LV3,RANK:20 )
在线值:
发帖
回帖
粉丝
2
感谢分享
2020-7-30 18:23
0
游客
登录 | 注册 方可回帖
返回
//