问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
带宏的恶意样本分析
分析一个带宏的恶意样本,通过宏代码释放恶意文件至本机执行,释放的恶意样本可实现多条远控功能
0x01 网络行为 ========= 122.216.201.108 0x02 持久化 ======== 将自身写入SOFTWARE\\\\Microsoft\\\\Windows\\\\CurrentVersion\\\\Run实现自启动 0x03 详细分析/功能介绍 ============== 3.1 宏代码分析 --------- Auto\_Open()子过程调用useraddeeLoadr 和 open\_pp两个子过程,useraddeeLoadr用于释放恶意文件wardhmrias.exe并执行,open\_pp打开ppt文件 data:image/s3,"s3://crabby-images/118c3/118c30d81b6030cdceb8f9bf35df1c0156037ec8" alt="image.png" useraddeeLoadr首先生成文件的释放路径 data:image/s3,"s3://crabby-images/33f10/33f10008fca3559315fd004062480283826b8865" alt="image.png" 然后根据不同操作系统版本,向Zip文件写入不同数据 data:image/s3,"s3://crabby-images/4b6a4/4b6a410ef276149a24032bd4c3d0afba3d0617b7" alt="image.png" 之后,在再将Zip中的文件解压出来,并执行 data:image/s3,"s3://crabby-images/d7d8e/d7d8e0ecb69a3c139d8421401c52344126146085" alt="image.png" Unaddeeip子过程,将Zip中的文件复制出来,完成解压操作 data:image/s3,"s3://crabby-images/030a4/030a44a816f67bf2ce6cd1a3402a19f4074fd4bb" alt="image.png" 3.2 wardhmrias.exe分析 -------------------- 接下来分析宏代码释放的恶意程序wardhmrias.exe。 首先观察入口点,判断为C#编写的WinForm程序 data:image/s3,"s3://crabby-images/872c0/872c00ef2dbc976391b75908786e696c54848e34" alt="image.png" 进入 Form1() ,首先进行组件初始化,并添加表单关闭和加载事件 data:image/s3,"s3://crabby-images/a73ff/a73ff9363140065e0bfd83a6a5fbf3311bb0f3bd" alt="image.png" 分析Form1\_FormClosing,该函数先判断wardhmrias.exe是否存在,不存在则创建一个新的wardhmrias.exe data:image/s3,"s3://crabby-images/0ef90/0ef9004c795e143004d05c09527b1289793eb22f" alt="image.png" data:image/s3,"s3://crabby-images/a801d/a801d9fd6b779bd99e03ffce0f25e95c1c0c27d2" alt="image.png" 然后将wardhmrias.exe写入注册表"SOFTWARE\\\\Microsoft\\\\Windows\\\\CurrentVersion\\\\Run,实现自启动 data:image/s3,"s3://crabby-images/43c11/43c118366ad719c158107fde10d65b1c287e3830" alt="image.png" Form1\_Load,设置窗体不可见 data:image/s3,"s3://crabby-images/acf67/acf67dfc3eb8a35351f86ea207102ef3b6938c20" alt="image.png" wardhmriasdo\_stadrt(),数据初始化,设置Timer data:image/s3,"s3://crabby-images/857e9/857e97f26eb942f77983fcf08782444f20c2b4af" alt="image.png" 通过计时器回调函数执行连接C2的操作 data:image/s3,"s3://crabby-images/835c3/835c355dc054808eef426769183a60ca489449cc" alt="image.png" 计时器回调函数为this.wardhmriasIPSrFI(); 创建socket,连接远程服务器 data:image/s3,"s3://crabby-images/acb4a/acb4acb16c3a52ba72d83ff78ce2a96cd4926733" alt="image.png" data:image/s3,"s3://crabby-images/f8ff6/f8ff66fd287a42db8b7bc4b7d0e5403dfebfe1a4" alt="image.png" data:image/s3,"s3://crabby-images/7e410/7e4100a1f18408d03eaa15a37a3a75defb2564bf" alt="image.png" wardhmriassee\_spyo() ,循环接收主控端命令,执行相应的操作。 先获取NetworkStream,再从中读取主控端发送的命令 data:image/s3,"s3://crabby-images/40ca1/40ca146cc0448746550250c58966b23bece9c611" alt="image.png" data:image/s3,"s3://crabby-images/ee4e0/ee4e00265d975ddbda6ab80db92200d4051de6f5" alt="image.png" data:image/s3,"s3://crabby-images/88282/88282f87e3c4689e9cd0620934c755e4ab855e35" alt="image.png" 创建命令字典 data:image/s3,"s3://crabby-images/fe534/fe5345fc15abdef61dcf20ec3f81c753b979a106" alt="image.png" 根据读取到的命令数据进行相应操作: "wardhmrias-puatsrt",1 将自己写入注册表 SOFTWARE\\\\Microsoft\\\\Windows\\\\CurrentVersion\\\\Run data:image/s3,"s3://crabby-images/79587/79587639d653de9f44dd9de4bbf04cda24032299" alt="image.png" data:image/s3,"s3://crabby-images/e2134/e213487d64a4decc6c50e7f789d010d88d31aa2f" alt="image.png" "wardhmrias-gedatavs",3 遍历进程,并将进程信息写入NetworkStream,发送主控端 data:image/s3,"s3://crabby-images/52232/5223296d6087ab55d61bd689491b2d82e3143da8" alt="image.png" data:image/s3,"s3://crabby-images/954c1/954c12762ee3064216ea6048373847bb9e8d8288" alt="image.png" 用于发送数据的函数如下 data:image/s3,"s3://crabby-images/3a0b4/3a0b41f6b65edbb1120dd8a746501f532ae37f51" alt="image.png" "wardhmrias-thdaumb",5 获取指定路径的图像文件及其名称、创建时间 data:image/s3,"s3://crabby-images/01544/01544a142713e58fbe0c514b5a3a26191292ecb6" alt="image.png" data:image/s3,"s3://crabby-images/9c491/9c491da8b0f1a0de92e1577829c5f9412165aa98" alt="image.png" "wardhmrias-praocl",7 遍历进程 data:image/s3,"s3://crabby-images/ca179/ca179ca3e88e3da6999b318b1ef4d9d3f575e5fa" alt="image.png" "wardhmrias-fialsz",9 获取指定路径的文件信息 data:image/s3,"s3://crabby-images/5b6ab/5b6ab9feafb893d6cbafa36f6cc171a36004ceaa" alt="image.png" data:image/s3,"s3://crabby-images/e1807/e1807270c7f698428d5985abc4e64ad1e9658418" alt="image.png" "wardhmrias-dodawf",11 读取数据并写入指定文件 data:image/s3,"s3://crabby-images/3a6d1/3a6d1cc2dd63a23272fa18c7bf4a78d2bbc4f9a5" alt="image.png" data:image/s3,"s3://crabby-images/74d61/74d6189dc1bd6e96ea4c67d6d2b974fc81ff0356" alt="image.png" data:image/s3,"s3://crabby-images/64be5/64be5fdba6197768c7c27797fce1ef959bea2cf3" alt="image.png" "wardhmrias-enadpo",13 结束指定进程 data:image/s3,"s3://crabby-images/bd8b4/bd8b416bbafeae334cbe1d43c11ad42e8b09841e" alt="image.png" "wardhmrias-scarsz",17 设置wardgmriasscrfSize data:image/s3,"s3://crabby-images/9ab9a/9ab9aa57440e74d64a27782e1d7ed06dcc8e08a5" alt="image.png" data:image/s3,"s3://crabby-images/8117a/8117a2c58801d327afa5bb963b00274919ea6d69" alt="image.png" "wardhmrias-diars",19 获取驱动信息 data:image/s3,"s3://crabby-images/45229/452295f843c3b272e7f46d95994bb2339bf4fad3" alt="image.png" data:image/s3,"s3://crabby-images/428ac/428ac596d8cd90f375f4d9e2ca4bb46c1c63735f" alt="image.png" data:image/s3,"s3://crabby-images/3bf74/3bf743bd2a4354d51c961fa2cba8d5540b122b56" alt="image.png" "wardhmrias-staops",21 设置标志位 data:image/s3,"s3://crabby-images/e317a/e317ae6a108bebc2b310b3aa5c630fa1b2bca331" alt="image.png" "wardhmrias-csdacreen",23 捕获屏幕 data:image/s3,"s3://crabby-images/c9eb4/c9eb4ef0fc6e2871c6a44005595f585e39baecb9" alt="image.png" data:image/s3,"s3://crabby-images/0dc88/0dc88490abe3cdc519624b433b5903e1f269527c" alt="image.png" data:image/s3,"s3://crabby-images/f9eaa/f9eaa96430cdcf52864afa5dbed0c5992fe7c008" alt="image.png" "wardhmrias-cnals",25 设置标志位 data:image/s3,"s3://crabby-images/f2af9/f2af90407a0a44580ef27bf6cdd7fc00003289fb" alt="image.png" "wardhmrias-doawr",27 同11 读数据写入文件 data:image/s3,"s3://crabby-images/0f5e5/0f5e580c5bdb6b5bfb87d1a9ce0447f5193305de" alt="image.png" "wardhmrias-scaren",29 创建线程捕获屏幕 data:image/s3,"s3://crabby-images/8c8e1/8c8e1c38da9ee2d83bb3c3bd1a1fed83a0e08212" alt="image.png" "wardhmrias-fladr",31 遍历指定路径的子目录(如果存在) data:image/s3,"s3://crabby-images/99c7b/99c7b7ae8c712b3e585f2d58edeb8b09a7e95e86" alt="image.png" data:image/s3,"s3://crabby-images/d63e9/d63e9e63f0d5b484c0756af74cb59dffa9182716" alt="image.png" "wardhmrias-udalt",33 读取NetStream数据写入debdrivca.exe文件并执行 data:image/s3,"s3://crabby-images/2e3ee/2e3eee6073f5838a27ad39262d9df22c6bac66b4" alt="image.png" data:image/s3,"s3://crabby-images/d1863/d1863318cba6de00898332be70a2c62a119d12d5" alt="image.png" "wardhmrias-inafo",35 获取用户相关信息 data:image/s3,"s3://crabby-images/7a6a5/7a6a59325feaa47f7faec8c9caf62c32d2dbb887" alt="image.png" data:image/s3,"s3://crabby-images/a72ed/a72ed0bd7d7834bfc37ff1abff14ed690a926291" alt="image.png" data:image/s3,"s3://crabby-images/d2797/d27970e3ac05e33f338eba2e9f7dd6097a8cab34" alt="image.png" data:image/s3,"s3://crabby-images/1ee16/1ee160cf980c20c95dfb7ad51b087410a9204316" alt="image.png" "wardhmrias-ruanf",37 启动指定进程 data:image/s3,"s3://crabby-images/1a118/1a1182e72736611b043a947eb87a943ec799fbb1" alt="image.png" data:image/s3,"s3://crabby-images/4c186/4c186501527e8cd4c23634b8c11479cdf2211e72" alt="image.png" "wardhmrias-fiale",39 获取指文件内容 data:image/s3,"s3://crabby-images/344e3/344e3f0163847fbe06077122beb8a7e052b1c9fa" alt="image.png" data:image/s3,"s3://crabby-images/ec6ee/ec6ee291089f61635b115bc9c2eff55da5b0f1ee" alt="image.png" "wardhmrias-dealt",41 删除文件 data:image/s3,"s3://crabby-images/08dcc/08dccc566fa6ca9e8a87621dfedb90694fc35d19" alt="image.png" data:image/s3,"s3://crabby-images/def8e/def8e6e966c0ca287cceed07b15f2e358e8296c6" alt="image.png" "wardhmrias-flaes",43 获取指定路径下的文件 data:image/s3,"s3://crabby-images/e3a23/e3a23e3302d8c84363025be19a4c2271b860517f" alt="image.png" data:image/s3,"s3://crabby-images/de4a8/de4a8179c0d9a178e51c456acfadc3de7851b4b3" alt="image.png" "wardhmrias-afaile",45 获取指定文件内容及相关信息 data:image/s3,"s3://crabby-images/0b9a0/0b9a09e64381e78e4edde4e419cac633a6da222d" alt="image.png" data:image/s3,"s3://crabby-images/af3eb/af3eb0d4b580e70a90ce17532655a4c3697d3174" alt="image.png" "wardhmrias-liastf",47 获取指定扩展名的文件 data:image/s3,"s3://crabby-images/47de4/47de4f54dd6e6ec0f342680f975ab6532e7c5146" alt="image.png" 检查命令是否完整: 扩展名+文件名 data:image/s3,"s3://crabby-images/be834/be83483d083f5eb0761436598cf73c98a06b15e9" alt="image.png" 检查文件扩展名 符合则获取相关文件信息发送服务器 data:image/s3,"s3://crabby-images/a2956/a2956ec8bad05cc72bd0b19a8bc4bd64b994c0c2" alt="image.png"
发表于 2022-05-25 09:33:24
阅读 ( 5321 )
分类:
其他
0 推荐
收藏
0 条评论
请先
登录
后评论
莫一
1 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!