本文整理匯總了Python中lief.parse方法的典型用法代碼示例。如果您正苦於以下問題:Python lief.parse方法的具體用法?Python lief.parse怎麽用?Python lief.parse使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類lief
的用法示例。
在下文中一共展示了lief.parse方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: find_main_arena
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def find_main_arena(libc_file):
binary = lief.parse(libc_file)
section = binary.get_section(".data")
data = bytearray(section.content)
m_type = binary.header.machine_type
arch_info = machine_types.get(m_type)
if arch_info is None:
return None
u_fmt, ptr_size = arch_info
ea = 0
while ea < section.size:
ptr = unpack(u_fmt, data[ea:ea+ptr_size])[0]
offset = ptr-section.virtual_address
if offset < ea:
if (ea-offset) in offsets[ptr_size]:
return ptr
ea += ptr_size
return None
示例2: scan
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def scan(self, payload: Payload, request: Request) -> WorkerResponse:
"""
Scan a payload using LIEF
"""
filename = payload.results.payload_meta.extra_data.get(
'filename', payload.results.payload_id
)
try:
binary = lief.parse(raw=payload.content, name=filename)
except lief.exception as err:
raise StoqPluginException(f'Unable to parse payload: {err}')
if binary is None:
raise StoqPluginException('The file type isn\'t supported by LIEF')
if self.abstract == True:
results = lief.to_json_from_abstract(binary.abstract)
else:
results = lief.to_json(binary)
return WorkerResponse(json.loads(results))
示例3: _analyze_elf
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def _analyze_elf(self, file_object):
elf_dict = {}
try:
parsed_binary = lief.parse(file_object.file_path)
binary_json_dict = json.loads(lief.to_json_from_abstract(parsed_binary))
if parsed_binary.exported_functions:
binary_json_dict['exported_functions'] = normalize_lief_items(parsed_binary.exported_functions)
if parsed_binary.imported_functions:
binary_json_dict['imported_functions'] = normalize_lief_items(parsed_binary.imported_functions)
if parsed_binary.libraries:
binary_json_dict['libraries'] = normalize_lief_items(parsed_binary.libraries)
except (TypeError, lief.bad_file) as error:
logging.error('Bad file for lief/elf analysis {}. {}'.format(file_object.uid, error))
return elf_dict
self.get_final_analysis_dict(binary_json_dict, elf_dict)
return elf_dict, parsed_binary
示例4: _verify_file
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def _verify_file(self, filename):
self._filename = filename
self._binary = lief.parse(filename)
if not self._binary:
self._output.info('file "%s" is not a executable, skipping...' % filename)
return
if self._binary.format != self._expected_format:
self._output.error('"%s" invalid executable format %s, expected %s'
% (self._filename, self._binary.format, self._expected_format))
return
self._binary = self._binary.concrete
self._output.info('checking file "%s"' % filename)
{
lief.EXE_FORMATS.ELF: self._verify_elf,
lief.EXE_FORMATS.PE: self._verify_pe,
lief.EXE_FORMATS.MACHO: self._verify_macho
}.get(self._binary.format)()
if self._shared is not None and not self._shared:
if self._is_shared_library:
self._output.error('"%s" is shared library, but option "shared" is set to "False"' % self._filename)
示例5: peloader
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def peloader(exe_file, emu, verbose=False):
""" Load a .exe file into emu's memory using LIEF """
pefile = lief.parse(exe_file)
if verbose:
print(f"[x] Loading .exe ...")
imagebase = pefile.optional_header.imagebase
for section in pefile.sections:
if verbose:
print(
f"[=] Writing {section.name} on {imagebase+section.virtual_address:x} - {imagebase+section.virtual_address+section.size:x}"
)
emu.map_space(imagebase+section.virtual_address, imagebase+section.virtual_address + section.size)
emu.emu.mem_write(imagebase+section.virtual_address, bytes(section.content))
emu.functions = {}
## Handle relocations
for r in pefile.relocations:
if r.symbol.is_function:
if r.symbol.value == 0:
rsv = r.address - (r.address & 1)
else:
rsv = r.symbol.value - (r.symbol.value & 1)
emu.functions[r.symbol.name] = rsv
if verbose:
print(f"Relocating {r.symbol.name} at {r.address:x} to {rsv:x}")
emu[r.address] = rsv
emu.function_names = {emu.functions[x]: x for x in emu.functions.keys()}
return pefile.entrypoint
示例6: __get_imports_with_library
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def __get_imports_with_library(self, filepath):
"""
Helper function to get the list of imported function calls for a binary
:param filepath: binary's absolute filepath
:return: the list of functions called/imported appended by their libraries.
"""
binary = lief.parse(filepath)
return [lib.name.lower() + ':' + e.name for lib in binary.imports for e in lib.entries]
示例7: __init__
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def __init__(self, binaryPath):
self.binary = lief.parse(binaryPath)
self.section = self.binary.get_section(".rdata")
self.imgBase = self.binary.optional_header.imagebase
self.ptr_size = 8 if self.binary.header.machine == lief.PE.MACHINE_TYPES.AMD64 else 4
self.content = self.section.content
self.sectionAddr = self.imgBase + self.section.virtual_address
self.pattern = b'W\x00N\x00F\x00_\x00' # key pattern used to find th wnf table
self.tableAddr = self.SearchForTable()
# Small generator providing the addresses of strings containing the [pattern]
示例8: load_binary
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def load_binary(self):
import lief
binary = lief.parse(GdbUtil().file)
phdrs = binary.segments
for phdr in phdrs:
size = phdr.physical_size
vaddr = phdr.virtual_address
self.log('[+] Loading 0x%06x - 0x%06x' % (vaddr, vaddr + size))
TritonContext.setConcreteMemoryAreaValue(vaddr, phdr.content)
示例9: evaluateImportTable
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def evaluateImportTable(self, binary, is_unmapped=True):
self._binary_length = len(binary)
results = {"import_table": []}
if lief:
lief_binary = lief.parse(bytearray(binary))
bitness = 32 if lief_binary.header.machine == lief.PE.MACHINE_TYPES.I386 else 64
for imported_library in lief_binary.imports:
for func in imported_library.entries:
if func.name:
results["import_table"].append((func.iat_address + self.load_offset, 0xFFFFFFFF, imported_library.name.lower() + "_0x0", func.name, bitness, True, 1))
else:
# fallback using the old method and out own import table parser
mapped_binary = binary
if is_unmapped:
LOG.debug("Mapping unmapped binary before processing")
mapped_binary = PeTools.mapBinary(binary)
bitness = PeTools.getBitness(mapped_binary)
self._import_table = None
self._parseImportTable(mapped_binary)
references = self._getCodeReferences(mapped_binary)
for offset, import_entry in sorted(self._import_table.items()):
ref_count = 1
if bitness:
ref_count = 1 + references[bitness][offset] if offset in references[bitness] else 1
results["import_table"].append((offset + self.load_offset, 0xFFFFFFFF, import_entry["dll_name"].lower() + "_0x0", import_entry["name"], bitness, True, ref_count))
return results
示例10: get_imphash
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def get_imphash(file_object):
if _is_elf_file(file_object):
try:
with suppress_stdout():
functions = normalize_lief_items(lief.parse(file_object.file_path).imported_functions)
return md5(','.join(sorted(functions)).encode()).hexdigest()
except Exception:
logging.error('Could not compute imphash for {}'.format(file_object.file_path), exc_info=True)
return None
示例11: process_object
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def process_object(self, file_object):
try:
elf_dict, parsed_binary = self._analyze_elf(file_object)
file_object.processed_analysis[self.NAME] = {'Output': elf_dict}
self.create_tags(parsed_binary, file_object)
file_object.processed_analysis[self.NAME]['summary'] = list(elf_dict.keys())
except RuntimeError:
logging.error('lief could not parse {}'.format(file_object.uid))
file_object.processed_analysis[self.NAME] = {'Output': {}}
return file_object
示例12: getCodeAreas
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def getCodeAreas(binary):
pefile = lief.parse(bytearray(binary))
code_areas = []
base_address = PeFileLoader.getBaseAddress(binary)
if pefile and pefile.sections:
for section in pefile.sections:
if section.characteristics & lief.PE.SECTION_CHARACTERISTICS.MEM_EXECUTE:
section_start = base_address + section.virtual_address
section_size = section.virtual_size
if section_size % 0x1000 != 0:
section_size += 0x1000 - (section_size % 0x1000)
section_end = section_start + section_size
code_areas.append([section_start, section_end])
return PeFileLoader.mergeCodeAreas(code_areas)
示例13: getBaseAddress
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def getBaseAddress(binary):
elffile = lief.parse(bytearray(binary))
# Determine base address of binary
#
base_addr = 0
candidates = [0xFFFFFFFFFFFFFFFF]
for section in elffile.sections:
if section.virtual_address:
candidates.append(section.virtual_address - section.offset)
if len(candidates) > 1:
base_addr = min(candidates)
return base_addr
示例14: mapBinary
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def mapBinary(binary):
# ELFFile needs a file-like object...
# Attention: for Python 2.x use the cStringIO package for StringIO
elffile = lief.parse(bytearray(binary))
base_addr = ElfFileLoader.getBaseAddress(binary)
LOGGER.debug("Assuming base address 0x%x for inference of reference counts (based on ELF header)", base_addr)
# find begin of the first and end of the last section
max_virt_section_offset = 0
min_raw_section_offset = 0xFFFFFFFFFFFFFFFF
for section in elffile.sections:
# print("{:20s} 0x{:08x} - 0x{:08x} / 0x{:08x}".format(section.name, section.header.sh_addr, section.header.sh_offset, section.header.sh_size))
if section.virtual_address:
max_virt_section_offset = max(max_virt_section_offset, section.size + section.virtual_address)
min_raw_section_offset = min(min_raw_section_offset, section.virtual_address)
# copy binary to mapped_binary
if max_virt_section_offset:
mapped_binary = bytearray([0] * (max_virt_section_offset - base_addr))
mapped_binary[0:min_raw_section_offset] = binary[0:min_raw_section_offset]
for section in elffile.sections:
if section.virtual_address:
rva = section.virtual_address - base_addr
mapped_binary[rva:rva + section.size] = section.content
return bytes(mapped_binary)
示例15: getBitness
# 需要導入模塊: import lief [as 別名]
# 或者: from lief import parse [as 別名]
def getBitness(binary):
# TODO add machine types whenever we add more architectures
elffile = lief.parse(bytearray(binary))
machine_type = elffile.header.machine_type
if machine_type == lief.ELF.ARCH.x86_64:
return 64
elif machine_type == lief.ELF.ARCH.i386:
return 32
return 0