码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 对某钓鱼样本分析


    HVV期间遇到一个钓鱼样本,用IDA简单分析下样本逻辑及C2信息。

    样本未做加壳处理,直接IDA打开,逻辑比较清晰,采用白加黑的方式进行免杀。

    涉及四个资源,跟进sub_140001000函数可以看到资源路径。

    用ResourceHacker打开,保存INSTALL中的二进制信息,可以看到其中有四个文件,

     分别对应主程序中的资源ID。两个黑文件,136->viewer.dll,135->log.dat,把dll恶意样本保存下来继续分析。

     可以看到shellcode的处理主要涉及到这两块。

    跟进sub_180002C60分析,逻辑非常复杂,给人看一眼就想放弃的感觉,而事实上很简单。文件大小作为输入参数,log.dat的字节数为0x40403,根据文件大小确定分支是直接内存copy,不做任何修改,差点被吓到。

    之后的解密就简单了,写了个脚本跑了下。 

    1. v17 = 1
    2. with open('log.dat','rb') as f:
    3.   k = f.read()
    4.   filesize = len(k)
    5. v22 = k
    6. m = bytearray(filesize)
    7. eax = 0
    8. for i in range(filesize):
    9.   v17 = (v17+3) << 21
    10.   eax = v17>>20
    11.   m[i] = (v22[i] ^ (eax & 0x0000ffff))
    12. with open('decode','wb') as f:
    13.   f.write(m)

    解出来shellcode,二进制查看,很明显的CS payload,CS的马网上分析的很多,需要对其进行解密加载,不再累述。

    下面就是shellcode中提取IOC数据,这里我简单写了个shellcode加载器,动态执行跟进即可,静态解密完全玩不转,放弃了,并且动态执行已风险可控。

    1. // shellcode_loader.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
    2. #include "pch.h"
    3. #include
    4. #include "windows.h"
    5. ​
    6. using namespace std;
    7. /* length: 798 bytes */
    8. const char shellcode[263171] = {0x90, 0x90, 0x90, 0x4d, 0x5a, 0x41, 0x52, 0x55, 0x48, 0x89, 0xe5,...};/*写入上述shellcode字节码*/
    9. const int shellcode_length = 263171;
    10. ​
    11. int main(int argc, char **argv)
    12. {
    13. void *exec = VirtualAlloc(0, sizeof shellcode, MEM_COMMIT, PAGE_EXECUTE_READWRITE);
    14. memcpy(exec, shellcode, sizeof(shellcode));
    15. ((void(*)())exec)();
    16. return 0;
    17. }

    扔到x64dbg中动态执行,可以看到相关C2地址:

  • 相关阅读:
    WMI 监控
    eslint和prettier实现代码格式化
    【环境搭建】linux docker安装nexus3
    docer安装hadoop
    测试/开发程序员的成长路线,全局思考问题的问题......
    Springboot楼盘在线销售平台7txdy计算机毕业设计-课程设计-期末作业-毕设程序代做
    AI相关资料整理
    i18next 国际化 & 与 React 联动
    Kubernetes 多集群管理平台 OCM v0.9.0 发布:进一步改善托管集群安全性问题
    【Java综合专栏】「渐入佳境」全链路追踪原理之Java Agent探针的底层运作原理和分析(中篇)
  • 原文地址:https://blog.csdn.net/vspiders/article/details/126269787
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号