mirror of
https://github.com/kh4sh3i/Malware-Analysis.git
synced 2024-12-18 10:26:08 +00:00
Malware analysis resources
forensicida-promalwaremalware-analysismalware-detectionmemory-forensicsmobsfreverse-engineeringvolatilitywindbgx64dbg
LICENSE | ||
malware.png | ||
README.md |
Malware Analysis
A curated list of awesome malware analysis tools and resources
Types of Malware Attacks
Type | What It Does | Real-World Example |
---|---|---|
Ransomware | disables victim's access to data until ransom is paid | RYUK |
Fileless Malware | makes changes to files that are native to the OS | Astaroth |
Spyware | collects user activity data without their knowledge | DarkHotel |
Adware | serves unwanted advertisements | Fireball |
Trojans | disguises itself as desirable code | Emotet |
Worms | spreads through a network by replicating itself | Stuxnet |
Rootkits | gives hackers remote control of a victim's device | Zacinlo |
Keyloggers | monitors users' keystrokes | Olympic Vision |
Bots | launches a broad flood of attacks | Echobot |
Mobile Malware | infects mobile devices | Triada |
Malware Analysis Proccess
-
Static Analysis
- Static Analysis can be done by checking physical states of file. In our case , we used executable file as static samples and to check the physical states of windows executable file Windows provide Portable Executable Format (PE Format) which describes the structure of executable (image) files and object files under the Windows family of operating systems. These files are referred to as Portable Executable (PE) files.
-
Dynamic Analysis
- Behaviour Analysis is similar to Dynamic Analysis therefore we created sandbox to find the behaviour of our malicious and good samples and these behaviour includes Registry Operations , Files Operations , Api's Calls , Dll loaded , Mutex Information etc
-
Code Analysis
- reversing code with debugger tools
- Debugging and Reverse Engineering ,Disassemblers, decompiler
-
Memory Analysis
- we dumping whole memory and checking for process and handler.
- we can find Rootkit and Ransomware Encryption key and find hidden process !
Tools
-
Static Analysis
- pestudio - Perform static analysis of Windows executables.
- CFF Explorer - is a suite of tools for portable executable (PE) checking import directory , export directory and section headers for finding packer [packer use for change pe table schema this UPX]
-
Dynamic Analysis
- Process Hacker - Tool that monitors system resources.
- Process Monitor - Advanced monitoring tool for Windows programs.
- RegShot - Registry compare utility that compares snapshots.
- ProcDot - A graphical malware analysis tool kit.
-
Code Analysis
-
Memory Forensics
- memory acquisition
- Comae-Toolkit _ use DumpIt.exe for sump whole memory
- memory analysis
- Volatility - Advanced memory forensics framework.
- memory acquisition
-
Online Scanners and Sandboxes
- Cuckoo Sandbox - Open source, self hosted sandbox and automated analysis system.
- VirusTotal - Free online analysis of malware samples and URLs
- Noriben - Uses Sysinternals Procmon to collect information about malware in a sandboxed environment.
- intezer analyzer - Create MITRE ATT&CK Technique Detection table
-
Network
- Wireshark - The network traffic analysis tool.
-
Android
- MobSF – Mobile Security Framework (MobSF) is an automated, all-in-one mobile application (Android/iOS/Windows) pen-testing, malware analysis and security assessment framework capable of performing static and dynamic analysis.
-
service emulation
Useful Language for learn
- Python
- C++
- Assembly
Useful Tools
- yara
- Python 3.8.0 - for ret-sync & ida module
- yara-python - require for ida module
- ret-sync - ret-sync is a set of plugins that helps to synchronize a debugging session (WinDbg/GDB/LLDB/OllyDbg2/x64dbg) with IDA/Ghidra/Binary Ninja disassemblers.
malicious Windows API
- malware tye
- downloader
- urldownloadtofile
- shellexec
- dropper
- findresource
- loadresource
- lockresource
- sizeofresource
- keylogger
- getkeystate
- getasynckeystate
- setwindowshook
- c2 server
- internetopenurla
- socket
- downloader
Tips
- every .exe file can hav some import dll or aeport dll or string
- new malware dos not use import dll and never call dll, and they are hard to hunt!
- use ida->view->subvie->string to see all sting
- ransomware encrpt data with symetric algoritm like sha256 and then send key to c2, they encrypt key with asymetric algoritm like RSA bublic key
- some malware hade digital signature, an attacker stole sign key from valid company
- for obfuscate pe file use packer
- Fuzzy Hashing tools like ssdeep can help hunter to find similarity between two malware with different md5 key
- Winexex in one of export function from kernel32.dll and can be malicious
- we can bypass all static analysis with rewrite import dll, with call function with address in memory
- we can create shellcode with FASM tools in assembly
- the best future of ida is create basic block for application analysis
- export procmon to csv and send to procdot for create png of malware behaviour
- almost ransomeware are 32 bit, because they can run on 32 bit and 64 bit architect
- some ransomware work when we have complex network, we use FakeNet tools for create all network service
- with FakeNet tools and vmware host only, we can see all network connection with c2 server, because 127.0.0.1 set for all dns query
- in windows 8 and upper, ther is patchgaurd mechanism that every 30m check critical section and if detedct some app remove linker and DKOM attack happen make bluescrean ! with this role most rootkit lose
- we can use psscan command in volatility for finding rootkit and hidden process
- .pdb file is so important for detection function name and indexing of system dll that use in malware
- in vmware we can suspend vm and copy .vmem for memory analysis. the file size is equal to whole memory size
- in ida pro use [tab] key to decompile code, use [x] key to find how many time item called in pe file
- in x64dbg with [F9] key we jumping to entrypoint of program, main function, work with F7,F8 for jumping code
Books
- Practical Malware Analysis
- Practical Reverse Engineering: x86, x64, ARM, Windows Kernel, Reversing Tools, and Obfuscation
reference
- A COMPLETE PRACTICAL APPROACH TO MALWARE ANALYSIS AND MEMORY FORENSICS - 2021 EDITION
- Awesome Malware Analysis
- Malware-analysis-and-Reverse-engineering
Thanks
Taha Tavakoli My Dear master in Malware Analysis Course