Given an unknown malware sample, it will first go through a classification process to determine if it is related to a known malware family. If the classification does not return any useful information, then a manual inspection will be needed.
For classification, one famous tool is the YARA identification and classification engine. Using YARA, you can create rules that detect strings, instruction sequences, regular expressions, byte patterns, etc. You can then scan files unsing the command-line yara utility or integrate the scanning engine into your own C or python tools with YARA's API.
The manual inspection is more complicated. In the end, it may require binary reverse engineering on the sample, which usually involves the use of disassembly tools such as IDA Pro and various analysis toolkits such as BinDiff. For disassembly, one famous open source tool is Ghidra from National Security Agency. It also works with BinDiff via the Ghidra BinExport extension.
In this project, please prepare a tutorial on the installation and usage of YARA, Ghidra, and BinDiff.
In the tutorial, you should give examples showing
- Creation of YARA rules to look for files containing specific strings (e.g., *.facebook.com)
- Disassembly and decompilation of binary executables
- Use of BinDiff to tell if two binaries contain similar code pieces (for instance, you can use BinDiff to compare a binary executable with a known library to see if the unknown executable uses a specific library)
- Windows 10 x64 1909
- Oracle JDK 11.0.6
Slides are located in folder "slides".
I created rules that can find urls and keyword: "expired" via RegExp in program.
For more details, see slides/01_YARA.pdf
│ 01_find_expire.yar
│ 01_find_url.yar
│
├───bin
│ yara64.exe
│ yarac64.exe
│
├───slides
│ 01_YARA.pdf
│
└───target
spacedeskWindowsVIEWER.exe
I found target program: "spacedeskWindowsVIEWER.exe" how does check the trial period.
For more details, see slides/02_Ghidra.pdf
├───slides
│ 02_Ghidra.pdf
│
└───target
spacedeskWindowsVIEWER.exe
In this part, it show how to compile binexport plugin for Ghidra, and compare two programs to see where are the difference the program implemented.
In last, we compare a program with static linked and others DLL library, to verify if that program used that library.
For more details, see slides/03_BinExport.pdf
I provided files that binexport exported, for copyright issues, I didn't upload exe file.
├───03_diff_src
│ a.BinExport
│ a.c
│ a.exe
│ b.BinExport
│ b.c
│ b.exe
│ Bin_Export_lib_check.7z
│
├───slides
│ 03_BinDiff.pdf