暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

pe文件签名信息检测技术

原创 科普云视界 2022-09-01
261

【摘要】 签名信息中包含有很多有用的信息,可以辅助对二进制软件进行安全检测。读者可以从本博客中了解到pe文件中签名信息是如何组织的,如何用python代码从pe文件中获取内嵌的签名信息等知识。

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

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

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

其中包括摘要算法、摘要加密算法等重要的密码学问题相关的信息
同时点击查看证书时,可以查看到证书详情信息,如下图所示:
image.png

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

pe文件如何保存这些签名信息数据的:
利用peview.exe工具来查看Ndis.sys驱动程序,可以看到签名信息存在于IMAGE_NT_HEADER结构里面,如下图所示:
image.png

该签名结构解析后可以得到签名信息在文件中的偏移地址和数据长度信息,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 Certificate
WIN_CERT_TYPE_X509 = 0x0001

# PKCS SignedData structure
WIN_CERT_TYPE_PKCS_SIGNED_DATA = 0x0002

# Reserved
WIN_CERT_TYPE_RESERVED_1 = 0x0003

# Terminal Server Protocol Stack Certificate signing
WIN_CERT_TYPE_TS_STACK_SIGNED = 0x0004

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

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
这些属性中嵌套有另外的签名证书结构数据

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

总结】利用python可以方便的解析pe文件中的签名详情信息,从而来验证该软件的签名信息是否符合相关安全规范要求,实现安全检测。

pe文件 python
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论

聚圣源起名用歆字美好寓意吗天上人间电视剧起名姓王姑娘名字洋气朔钢窗价格知足常乐什么意思免费取起名网女孩起名字珊珊的意思百变小樱国语急先锋下载舟起名的含义公狗起名嘟囔的意思人族无敌攻略公司起名字怎么查破冰行动在线播放网红逆袭指北驻马店驿城区的起名馆crushfetish众字起公司名巴顿将军超级浮空城加盟仙芋传奇那片海歌词藏语名字五星直播邻家有女初长成txt蛋糕店起名简洁响亮商标起名规则朝日电视台成福安淀粉肠小王子日销售额涨超10倍罗斯否认插足凯特王妃婚姻让美丽中国“从细节出发”清明节放假3天调休1天男孩疑遭霸凌 家长讨说法被踢出群国产伟哥去年销售近13亿网友建议重庆地铁不准乘客携带菜筐雅江山火三名扑火人员牺牲系谣言代拍被何赛飞拿着魔杖追着打月嫂回应掌掴婴儿是在赶虫子山西高速一大巴发生事故 已致13死高中生被打伤下体休学 邯郸通报李梦为奥运任务婉拒WNBA邀请19岁小伙救下5人后溺亡 多方发声王树国3次鞠躬告别西交大师生单亲妈妈陷入热恋 14岁儿子报警315晚会后胖东来又人满为患了倪萍分享减重40斤方法王楚钦登顶三项第一今日春分两大学生合买彩票中奖一人不认账张家界的山上“长”满了韩国人?周杰伦一审败诉网易房客欠租失踪 房东直发愁男子持台球杆殴打2名女店员被抓男子被猫抓伤后确诊“猫抓病”“重生之我在北大当嫡校长”槽头肉企业被曝光前生意红火男孩8年未见母亲被告知被遗忘恒大被罚41.75亿到底怎么缴网友洛杉矶偶遇贾玲杨倩无缘巴黎奥运张立群任西安交通大学校长黑马情侣提车了西双版纳热带植物园回应蜉蝣大爆发妈妈回应孩子在校撞护栏坠楼考生莫言也上北大硕士复试名单了韩国首次吊销离岗医生执照奥巴马现身唐宁街 黑色着装引猜测沈阳一轿车冲入人行道致3死2伤阿根廷将发行1万与2万面值的纸币外国人感慨凌晨的中国很安全男子被流浪猫绊倒 投喂者赔24万手机成瘾是影响睡眠质量重要因素春分“立蛋”成功率更高?胖东来员工每周单休无小长假“开封王婆”爆火:促成四五十对专家建议不必谈骨泥色变浙江一高校内汽车冲撞行人 多人受伤许家印被限制高消费

聚圣源 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化