lief模块使用

使用lief模块解析pe文件信息

简介

lief是一个测试可执行格式的库

安装

pip install lief

用法

import json

import lief

pe_file = r"D:\Program Files\JetBrains\PyCharm 2022.3\bin\pycharm64.exe"
binary = lief.parse(open(pe_file, 'rb'))
data = json.loads(lief.to_json(binary))
print(json.dumps(data, indent=4))

读取文件说明信息

def read_FileDescription(file):
    """读取文件说明信息"""
    binary = lief.parse(open(file, 'rb'))
    try:
        d = json.loads(lief.to_json(binary))
        file_info = d.get('resources_manager').get('version').get('string_file_info')
        FileDescription = file_info.get('langcode_items')[0].get('items').get('FileDescription')
        return FileDescription
    except:
        return

读取文件数字签名信息

def get_certificate_info(self, file):
    binary = lief.parse(file)
    d = json.loads(lief.to_json(binary))
    issuer = d["signatures"][0]['signer_info'][0]["issuer"]
    lst = d["signatures"][0]['certificates']
    for item in lst:
        if item['issuer'] == issuer:
            name = item['subject'].split("=")[-1]
            valid = item['valid_to']
            return name, datetime.datetime(*valid)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值