Skip to content

Latest commit

 

History

History
124 lines (92 loc) · 4.48 KB

README.md

File metadata and controls

124 lines (92 loc) · 4.48 KB

BFG

Update

BFG is now merged into AVET: https://github.com/govolution/avet/

What & Why:

  • bfg is a tool that helps you to inject and execute shellcode/executables
  • it uses some concepts from https://github.com/govolution/avet
  • it is not meant to be another antivirus evasion tool
  • this README applies to the use on Kali 2 (64bit) and tdm-gcc

How to install tdm-gcc with wine: https://govolution.wordpress.com/2017/02/04/using-tdm-gcc-with-kali-2/

How to use make_bfg and build scripts

Even though a prebuilt make_bfg executable is given in the repository, you should compile it for your system:

$ gcc -o make_bfg make_bfg.c

The purpose of make_bfg is to preconfigure a definition file (defs.h) so that the source code can be compiled in the next step. Let's have a look at the options of make_bfg, examples will be given further below:

-i inject
	-i shellcode to be used for shellcode injection
	-i dll dll injection
-H Hollow target process and insert payload executable. Usage: bfg.exe target.exe
	Set -x flag to XOR-obfuscate the payload with a random byte key
	Set -a flag to use alternative obfuscation which is a little more complex
	It would be unwise to use both obfuscations at once. You have been warned...
	Set -X flag to specify that the hollowing target is a 64 bit process
-P inject shellcode by PID as argument, call bfg.exe PID for sc and bfg.exe my.dll PID for dll injection
-I inject shellcode by image name, call for example: pwn.exe keepass.exe
-l load and exec shellcode from given file, call is with mytrojan.exe myshellcode.bin
-f compile and insert shellcode into .exe, needs filename of shellcode file
-X compile for amd64 architecture
-p print debug information
-q quiet mode (hide console window)
-h help

Of course it is possible to run all commands step by step from command line. But it is strongly recommended to use build scripts or the bfg_fabric.py.

The build scripts themselves are written so as they have to be called from within the bfg directory:

root@kalidan:~/tools/bfg# ./build/build_win32_meterpreter_rev_https_shikata_loadfile.sh 

Here are some explained examples for building the .exe files from the build directory. Please have a look at the build scripts for further explanation.

Examples

Please refer to the files in the build directory.

build_win32_hollowing_hello_exe.sh
Hollow target 32 bit process and insert payload executable (here a simple exe with a messagebox).

build_win32_hollowing_revtcp_exe.sh
Hollow target 32 bit process and insert payload executable (here a metasploit-generated tcp reverse shell).

build_win32_load_exec_dll.sh
Simply loads and execs a dll.

build_win32_meterpreter_rev_https_50xshikata.sh
Loads and execute a shellcode, the shellcode is compiled into the .exe file.

build_win32_meterpreter_rev_https_shikata_loadfile.sh 
Loads and execute a shellcode from a file.

build_win32_msgbox_inject_dll_imagename.sh
Inject a dll by the imagename.

build_win32_msgbox_inject_dll.sh
Inject a dll by the PID. Call with bfg.exe yourdll.dll PID.

build_win32_msgbox_inject_shellcode.sh
Inject a shellcode into a process by PID.

build_win32_msgbox_inject_shellcode_loadfile.sh
Inject and load a shellcode into a process by PID.

build_win32_msgbox_inject_shellcode_imagename.sh
Loads and execute a shellcode that is injected into a process. Therefore the name of 
the process (imagename) has to be specified.

build_win32_load_exec_dll.sh
Build an exe file that loads & execs a dll.

build_win64_bind_tcp_inject_dll.sh
Inject a dll by the PID. Call with bfg.exe yourdll.dll PID.

build_win64_bind_tcp_inject_shellcode.sh
Inject a 64bit shellcode into a 64bit process.

build_win64_hollowing_hello_exe.sh
Hollow target 64 bit process and insert payload executable (here a simple exe with a messagebox).

build_win64_hollowing_revtcp_exe.sh
Hollow target 64 bit process and insert payload executable (here a metasploit-generated tcp reverse shell).

bfg_fabric.py

bfg_fabric is an assistant, that loads all build scripts in the build directory (name has to be build*.sh) and then lets the user edit the settings line by line.

Further information

A short explanation about process hollowing mechanics, of which some are used in this project, can be found in this presentation: https://github.com/tacticaljmp/hollowing-presentation

Credits

https://github.com/securestate/syringe

https://github.com/tacticaljmp/humble-file-crypter

https://github.com/hasherezade/demos