网络编程
位置:首页>> 网络编程>> Python编程>> Python利用capstone实现反汇编

Python利用capstone实现反汇编

作者:lyshark  发布时间:2022-08-08 17:50:52 

标签:Python,capstone,反汇编

Capstone是Kali Linux自带的一款轻量级反汇编引擎。它可以支持多种硬件构架,如ARM、ARM64、MIPS、X86。该框架使用C语言实现,但支持C++、Python、Ruby、OCaml、C#、Java和Go语言,具有很好的扩展性。因此,该框架被256种工具所集成,如Cuckoo、Binwalk、IntelliJ IDEA。渗透测试人员一额可以通过Python、Ruby语言编写脚本,引入Capstone引擎,从而构建自己的反汇编工具。

Capstone作为一个轻量级的多平台、多架构的反汇编框架,该模块支持目前所有通用操作系统,反汇编架构几乎全部支持。

capstone使用起来非常简单,如果只需要静态反汇编,则几行代码即可完成该功能了。

from capstone import *

# powerby LyShark
def Disassembly(path,BaseAddr,FileOffset,ReadByte):
   with open(path,"rb") as fp:
       fp.seek(int(FileOffset))
       opcode = fp.read(int(ReadByte))

md = Cs(CS_ARCH_X86, CS_MODE_32)
   for item in md.disasm(opcode, 0):
       addr = int(BaseAddr) + item.address
       dic = {"Addr": str(addr) , "OpCode": item.mnemonic + " " + item.op_str}
       print(dic)

if __name__ == "__main__":
   # 文件名 内存地址 开始位置 长度
   Disassembly("d://Win32Project.exe",401000,0,1024)

如果需要针对.text节进行反汇编,则需要通过pefile模块找到该节所对应到文件中的位置,并从该位置开始向下反编译即可,代码如下:

from capstone import *
import pefile

# 遍历整个可执行文件并返回汇编代码,有一个小Bug
# powerby LyShark
def FOA_Disassembly(FilePath):
   opcode_list = []
   pe = pefile.PE(FilePath)
   ImageBase = pe.OPTIONAL_HEADER.ImageBase

for item in pe.sections:
       if str(item.Name.decode('UTF-8').strip(b'\x00'.decode())) == ".text":
           # print("虚拟地址: 0x%.8X 虚拟大小: 0x%.8X" %(item.VirtualAddress,item.Misc_VirtualSize))
           VirtualAddress = item.VirtualAddress
           VirtualSize = item.Misc_VirtualSize
           ActualOffset = item.PointerToRawData
   StartVA = ImageBase + VirtualAddress
   StopVA = ImageBase + VirtualAddress + VirtualSize
   with open(FilePath,"rb") as fp:
       fp.seek(ActualOffset)
       HexCode = fp.read(VirtualSize)

md = Cs(CS_ARCH_X86, CS_MODE_32)
   for item in md.disasm(HexCode, 0):
       addr = hex(int(StartVA) + item.address)
       dic = {"Addr": str(addr) , "OpCode": item.mnemonic + " " + item.op_str}
       print("[+] 反汇编地址: {} 参数: {}".format(addr,dic))
       opcode_list.append(dic)
   return opcode_list

if __name__ == "__main__":
   ref = FOA_Disassembly("d://Win32Project.exe")
   print(ref)

Python利用capstone实现反汇编

来源:https://www.cnblogs.com/LyShark/p/16099380.html

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com