Skip to content

Latest commit

 

History

History
212 lines (167 loc) · 9.02 KB

README.md

File metadata and controls

212 lines (167 loc) · 9.02 KB

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

    • Disassembler
    • Decompiler
    • debuggers
      • X64dbg - An open-source x64/x32 debugger for windows.
      • WinDbg - multipurpose debugger for the Microsoft Windows computer operating system
  • Memory Forensics

    • memory acquisition
    • memory analysis
      • Volatility - Advanced memory forensics framework.
  • 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

    • INetSim - Network service emulation, useful when building a malware lab.
    • FakeNet - Windows Network Simulation tool for Malware Analysis

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

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

reference

Thanks

Taha Tavakoli My Dear master in Malware Analysis Course