0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

pe文件签名信息检测技术

秃头也爱科技 来源:秃头也爱科技 作者:秃头也爱科技 2022-10-13 15:43 次阅读

什么是pe文件的签名信息

以windows系统中NDIS.sys驱动程序为例,在该文件的右键属性窗口中,若包含数字签名属性页,则表示该pe文件内嵌有签名信息,如下图所示:

IMG_256当双击签名列表时,可以查看数字签名信息详情,如下图所示:

IMG_257

在详情中包含了__签名者信息__以及__签名时间戳__等重要的信息,同时查看高级属性页时,可以看到更加丰富的签名信息,如下图所示:

IMG_258

其中包括__摘要算法、摘要加密算法等重要的密码学问题相关的信息__。

同时点击查看证书时,可以查看到证书详情信息,如下图所示:

IMG_259

从中可以看到__颁发者、证书有效期、公钥长度等重要信息__。安全工具可以通过分析以上这些重要信息来判断是否存在安全风险。比如是否使用了不安全密码学算法、密钥长度是否满足安全规范、证书有效期是否有效等等。

pe文件如何保存这些签名信息数据的:

利用peview.exe工具来查看Ndis.sys驱动程序,可以看到签名信息存在于__IMAGE_NT_HEADER结构__里面,如下图所示:

IMG_260

该签名结构解析后可以得到签名信息在文件中的__偏移地址和数据长度__信息, python代码如下

security_entry = pefile.DIRECTORY_ENTRY["IMAGE_DIRECTORY_ENTRY_SECURITY"]
sig_off = pe_obj.OPTIONAL_HEADER.DATA_DIRECTORY[security_entry].VirtualAddress
sig_len = pe_obj.OPTIONAL_HEADER.DATA_DIRECTORY[security_entry].Size

根据偏移地址和数据长度获取签名数据,python代码如下:

with open(file_path, 'rb') as fh:
   fh.seek(sig_off)
   sig_raw_data = fh.read(sig_len)

# 签名数据的结构如下:
# DWORD   dwLength           签名证书数据长度
# WORD    wRevision           签名证书的版本号
# WORD    wCertificateType      签名证书类型
# BYTE     bCertificate[dwLength] 签名证书数据

# 签名证书的版本号
# Version 1 is the legacy version of WIN_CERTIFICATE.WIN_CERT_REVISION_1_0 = 0x0100

# Version 2 is the current version of WIN_CERTIFICATE.WIN_CERT_REVISION_2_0 = 0x0200

# 签名证书类型
# X.509 CertificateWIN_CERT_TYPE_X509 = 0x0001

# PKCS SignedData structureWIN_CERT_TYPE_PKCS_SIGNED_DATA = 0x0002

# ReservedWIN_CERT_TYPE_RESERVED_1 = 0x0003

# Terminal Server Protocol Stack Certificate signingWIN_CERT_TYPE_TS_STACK_SIGNED = 0x0004

使用ASN.1 Editor工具可以查看签名证书数据,如下图所示:

IMG_261

Python中可以利用__asn1crypto组件来实现对签名证书的解__析,python样例代码如下:

info = cms.ContentInfo.load(seq_data)
signed_data = info['content']
cert_set = signed_data["certificates"]

#通过遍历cert_set可以获取所有证书详情信息for cert in cert_set:
cert_data = cert.dump()
cert = x509.Certificate.load(cert_data)
#解析cert就可以获取证书详情信息

#通过查找id-ct-TSTInfo content type 1.2.840.113549.1.9.16.1.4来获取签名时间信息
encap_content_info = signed_data['encap_content_info']
# id-ct-TSTInfo content type
tst_info = tsp.TSTInfo.load(encap_content_info['content'].parsed.dump())
signing_time = tst_info['gen_time'].native.astimezone().strftime('%Y-%m-%d %H:%M:%S')

另外在签名数据中包含有非签名的数据属性,python样例代码如下:
signer_info = cms.SignerInfo.load(obj.contents)
attrs = signer_info['unsigned_attrs']

需要注意的是不同的签名属性,获取签名时间戳等信息的方法是不同的,常见的属性有:

counter_signaturemicrosoft_nested_signaturemicrosoft_time_stamp_token

这些属性中嵌套有另外的签名证书结构数据

通过这些层层数据结构的解析就可以获取到所有的证书详情信息,如下图所示

IMG_262

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • WINDOWS
    +关注

    关注

    3

    文章

    3545

    浏览量

    88686
  • PE文件
    +关注

    关注

    0

    文章

    4

    浏览量

    5441
  • 信息检测
    +关注

    关注

    0

    文章

    4

    浏览量

    5826
收藏 人收藏

    评论

    相关推荐

    RK3288 apk签名方法(提供完整签名文件

    `apk签名方法:环境:Ubuntu系统需要的文件:testkey.pk8 testkey.x509.pem signapk.jar附件已经上传把上面几个文件放到目标apk文件夹中进入
    发表于 08-12 08:22

    OpenHarmony应用的签名配置的流程解析

    ,具体请访问HUAWEI DevEco Studio使用指南 (opens new window)。配置应用签名信息的流程如下图所示。   生成密钥和证书请求文件  OpenHarmony应用通过
    发表于 03-14 16:40

    鸿蒙原生应用/元服务开发-AGC分发如何配置签名信息

    使用制作的私钥(.p12)文件、在AGC申请的证书文件和Profile(.p7b)文件,在DevEco Studio配置工程的签名信息,以构
    发表于 11-23 11:06

    签名签名”之实现技术研究

    介绍“签名签名”,即笔迹数字签名的概念,提出直接和需仲裁的“签名签名”之2种结构模式。针对签名
    发表于 04-20 09:30 15次下载

    基于PE文件格式的信息隐藏技术研究

    根据PE 文件结构的特点,提出了利用PE 文件结构中的冗余空间,冗余字段和利用PE 文件中静态分
    发表于 07-08 09:22 10次下载

    JPEG文件隐形信息检测算法

    JPEG文件隐形信息检测算法::隐秘信息分析的目的是正确分辨出文件中是否带有隐藏的信息.自然图像
    发表于 10-26 11:37 15次下载

    PE管超声检测试验

    测量了PE 管的纵横波声速及PE 管热熔焊缝声衰减系数,确定了PE 管材料的声学性能。采用小波域去噪理论去除噪声,提高了检测回波的信噪比。试验表明,超声
    发表于 11-23 14:46 10次下载

    数字签名,什么是数字签名

    数字签名,什么是数字签名 在数字签名技术出现之前,曾经出现过一种“数字化签名技术,简单地说就
    发表于 04-03 16:00 6321次阅读

    PE_SETUP

    PE独立安装包文件PE维护系统安装后开机可直接选择进入。
    发表于 03-18 17:12 1次下载

    XML加密和签名技术信息安全中的研究与应用_欧海蕉

    XML加密和签名技术信息安全中的研究与应用_欧海蕉
    发表于 03-19 11:28 0次下载

    多重签名技术介绍

    多重签名技术(multisig)就是多个用户同时对一个数字资产进行签名。可以简单的理解为,一个账户多个人拥有签名权和支付权。 如果一个地址只能由一个私钥
    发表于 06-04 10:00 2542次阅读

    PE管的外径尺寸检测

        PE管可用于电热熔管件、热熔对接管件、承插管件、钢塑转换接头等。用途广泛,为了能更好的保证其质量,在线检测外径是必不可少的一项检测手段,在线检测可保证产品外径质量,实时调控生产
    发表于 03-18 15:39 1550次阅读

    Schnorr签名和ECDSA签名技术介绍

    Schnorr签名是一个使BCH区块链实现技术领先的强大功能,因为Schnorr签名方案直接促进了BCH的隐私性和交易能力。Schnorr签名算法是由著名的密码学家Claus Schn
    发表于 05-16 10:32 2806次阅读

    区块链数字签名技术的过程及原理介绍

    签名:在现实社会中,签名作为签名者身份的一种证明,签名代表对签名文件的认可,不可抵赖。理论上签名
    发表于 06-14 14:10 2.1w次阅读
    区块链数字<b class='flag-5'>签名</b><b class='flag-5'>技术</b>的过程及原理介绍

    数字签名技术的应用

    加密领域的技术来实现的,用于鉴别数字信息的方法。一套数字签名通常定义两种互补的运算,一个用于签名,另一个用于验证。数字签名是非对称密钥加密
    的头像 发表于 08-20 11:31 7869次阅读
    数字<b class='flag-5'>签名</b><b class='flag-5'>技术</b>的应用