nim-lang callback uuid shellcode

0x00 描述

Nim(最初叫 Nimrod)是⼀⻔命令式静态类型编程语⾔,可以被编译成 C 或 JavaScript。它是开源的,维护很活跃,还结合了 来⾃成熟语⾔(如Python,Ada和Modula)的成功概念。 Nim具有⾼效性,⽣成的执⾏⽂件⼩,编译器⽀持所有平台,⾮常适合嵌⼊式硬实时系统,⽀持各种后端编译等等,Nim强⼤的宏 系统和独⽴性,接下来将介绍如何利⽤Nim结合⼀些未被⼤规模滥⽤的winapi进⾏免杀。

本⽂测试将shellcode转换为 string UUID,再利⽤API将string UUID转换为⼆进制,并通过回调函数的 ⽅式调⽤内存地址加载执⾏shellcode。

Windows安装nim https://hl4.gitee.io/install_windows.html

0x01 主要过程-涉及到的API

主要过程可概括为:
1.shellcode.bin:将 bytes 转成 string UUID
2.创建并分配堆内存
3.将shellcode写⼊堆内存
4.执⾏shellcode

1.1 将 bytes 转成 string UUID
UUID是⼀个由4个连字号(-)将32个字节⻓的字符串分隔后⽣成的字符串,总共36个字节⻓。 ⽐如: "\xfc\x48\x83\xe4\xf0\xe8\xc8\x00\x00\x00\x41\x51\x41\x50\x52\x51"
"e48348fc-e8f0-00c8-0000-4151
①使⽤python代码转换

代码地址:https://github.com/ChoiSG/UuidShellcodeExec/blob/main/shellcodeToUUID.py 修改shellcode即可:

ToUUID.jpeg

为了后⾯好操作,最好删掉原来sep的\n:

ToUUID.jpeg

convert.jpeg

②使⽤nim转换 https://github.com/StudyCat404/uuid_exec_shellcode/blob/main/greetings.nim
image.jpeg

--使⽤copyMem先将 bytes 转为 binary
--使⽤UuidToStringA函数,将binary UUID转换为String UUID

RPC_STATUS UuidToStringA( 
          const UUID *Uuid, 
          RPC_CSTR *StringUuid );

参数:
● Uuid:指向⼆进制UUID的指针
● StringUuid:指向存放UUID格式的字符串的指针

--调⽤gkkaekgaEE($uidStr, password)传⼊string uuid的shellcode 和随机⽣成的key进⾏xor处理

gkkaekgaEE.jpeg

最后会将所得的uuid存放与同⼀⽬录下的uuid.txt,key显示在console上

1.2 创建并分配堆内存
创建堆:HeapCreate

HANDLE HeapCreate( 
              DWORD flOptions, 
              SIZE_T dwInitialSize, 
              SIZE_T dwMaximumSize );

参数:

● flOptions:需要为有执⾏权限的关键字:

● dwInitialSize:初始化⼤⼩--0

HEAP_CREATE_ENABLE_EXECUTE

● dwMaximumSize:最⼤值--0(根据系统⼤⼩确定)

分配堆内存:HeapAlloc

DECLSPEC_ALLOCATOR LPVOID HeapAlloc( 
                HANDLE hHeap, 
                DWORD dwFlags, 
                SIZE_T dwBytes );

参数:
● hHeap:要分配堆的句柄
● dwFlags:堆分配时的可选参数
● dwBytes:要分配堆的字节数

1.3 将shellcode写⼊堆内存
①将UUDI转换为⼆进制

RPC_STATUS UuidFromStringA( 
        RPC_CSTR StringUuid, 
        UUID *Uuid );

参数:

● StringUuid:指向UUID表示形式的字符串的指针
● Uuid:以⼆进制形式返回指向UUID的指针

②将转换出的Uuid所指内容放⼊堆内存中

1.4 执⾏shellcode

BOOL EnumSystemLocalesA( 
          LOCALE_ENUMPROCA lpLocaleEnumProc, 
          DWORD dwFlags );

参数:
● lpLocaleEnumProc:指定回调函数(指向应⽤程序定义的回调函数的指针)
● dwFlags:指定0默认为 LCID_SUPPORTED (枚举所有⽀持的语⾔环境标识符)

0x02 使⽤⽅式

nim编译成exe:
nim c filename.nim

修改SIZEUUIDARR:
UUIDARR对应string UUID
SIZE对应UUID的长度

替换UUID shellcode.jpeg

注意:数组元素不能有换⾏
byt3bl33d3r版本: https://github.com/byt3bl33d3r/OffensiveNim/blob/master/src/uuid_exec_bin.nim 没有shellcode没有xor加密,可以直接结合[1.1中的python版]转换⽅式使⽤

StudyCat版本: 多了xor加密,使⽤[1.1中的nim版]转换,还需要替换xorpassword https://github.com/StudyCat404/uuid_exec_shellcode/blob/main/uuid_exec_bin.nim

0x03 上线测试

对python转换使⽤CS⽣成的x64.c
对nim转换使⽤CS⽣成x64.bin


bypass.jpeg

可绕过主流杀软。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • ![Flask](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAW...
    极客学院Wiki阅读 7,229评论 0 3
  • 不知不觉易趣客已经在路上走了快一年了,感觉也该让更多朋友认识知道易趣客,所以就谢了这篇简介,已做创业记事。 易趣客...
    Physher阅读 3,407评论 1 2
  • 双胎妊娠有家族遗传倾向,随母系遗传。有研究表明,如果孕妇本人是双胎之一,她生双胎的机率为1/58;若孕妇的父亲或母...
    邺水芙蓉hibiscus阅读 3,694评论 0 2
  • 晴天,拥抱阳光,拥抱你。雨天,想念雨滴,想念你。 我可以喜欢你吗可以啊 我还可以喜欢你吗可以,可是你要知道我们不可...
    露薇霜凝阅读 1,202评论 1 2