开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 168|回复: 4
收起左侧

[已解决] 如何获得文件的{guid}{age}

 关闭 [复制链接]
结帖率:92% (12/13)
发表于 昨天 09:45 | 显示全部楼层 |阅读模式   安徽省淮北市
50精币
最近研究内核pdb,在内核中下载pdb文件太麻烦了,我想在r3中下载pdb,但是没找到易语言如何获得文件的{guid}{age},

比如获取本机
C:\Windows\System32\ntdll.dll
文件的{guid}{age}

各位大佬贡献一下方法

返回结果像这种:0AF9B92CB2856CFB0C54EC42CE8E33771


0AF9B92CB2856CFB0C54EC42CE8E3377 是 guid   1是age



补充内容 (2026-3-28 09:45):
对哦,好像32位会重定向目录

最佳答案

查看完整内容

[mw_shl_code=python,true]import struct import os def get_pdb_info(file_path): with open(file_path, 'rb') as f: # 1. 解析 DOS 头 dos_header = f.read(64) if dos_header[:2] != b'MZ': return None e_lfanew = struct.unpack('

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值
结帖率:92% (12/13)

签到天数: 22 天

 楼主| 发表于 昨天 16:34 | 显示全部楼层   安徽省淮北市
自己解决了,用c++写exe读取文件的guid,然后用易语言调用c++的exe读取
回复

使用道具 举报

结帖率:81% (22/27)

签到天数: 6 天

发表于 昨天 09:45 | 显示全部楼层   湖北省孝感市

[Python] 纯文本查看 复制代码
import struct
import os

def get_pdb_info(file_path):
    with open(file_path, 'rb') as f:
        # 1. 解析 DOS 头
        dos_header = f.read(64)
        if dos_header[:2] != b'MZ':
            return None
        
        e_lfanew = struct.unpack('<I', dos_header[60:64])[0]
        
        # 2. 解析 NT 头 (PE Signature + FileHeader + OptionalHeader)
        f.seek(e_lfanew)
        nt_signature = f.read(4)
        if nt_signature != b'PE\x00\x00':
            return None
        
        # 跳转到 Optional Header (20字节的 FileHeader 之后)
        f.seek(e_lfanew + 4 + 20)
        magic = struct.unpack('<H', f.read(2))[0]
        
        # 判断是 PE32 (0x10B) 还是 PE32+ (0x20B)
        is_64bit = magic == 0x20b
        
        # DataDirectory 的偏移 (Optional Header 中部)
        # PE32: 96 字节处开始, PE32+: 112 字节处开始
        data_dir_offset = e_lfanew + 4 + 20 + (112 if is_64bit else 96)
        
        # Debug Directory 是第 7 个条目 (Index 6)
        f.seek(data_dir_offset + 6 * 8)
        debug_vaddr, debug_size = struct.unpack('<II', f.read(8))
        
        if debug_vaddr == 0 or debug_size == 0:
            return None

        # 3. 将虚拟地址 (RVA) 转换为文件偏移 (File Offset)
        # 简单起见,遍历 Section Headers
        num_sections = struct.unpack('<H', dos_header[e_lfanew+6:e_lfanew+8])[0]
        # Section Header 在 Optional Header 之后
        # Optional Header 大小在 File Header 中定义
        opt_header_size = struct.unpack('<H', dos_header[e_lfanew+20:e_lfanew+22])[0]
        section_table_offset = e_lfanew + 4 + 20 + opt_header_size
        
        f.seek(section_table_offset)
        debug_file_offset = 0
        for _ in range(num_sections):
            sect = f.read(40)
            s_vaddr = struct.unpack('<I', sect[12:16])[0]
            s_vsize = struct.unpack('<I', sect[8:12])[0]
            s_rawptr = struct.unpack('<I', sect[20:24])[0]
            if s_vaddr <= debug_vaddr < s_vaddr + s_vsize:
                debug_file_offset = s_rawptr + (debug_vaddr - s_vaddr)
                break
        
        if debug_file_offset == 0: return None

        # 4. 解析 Debug Directory 数组
        f.seek(debug_file_offset)
        for _ in range(debug_size // 28): # 每条 IMAGE_DEBUG_DIRECTORY 是 28 字节
            data = f.read(28)
            dtype = struct.unpack('<I', data[12:16])[0]
            if dtype == 2: # IMAGE_DEBUG_TYPE_CODEVIEW
                raw_ptr = struct.unpack('<I', data[24:28])[0]
                f.seek(raw_ptr)
                cv_sig = f.read(4)
                if cv_sig == b'RSDS':
                    guid = f.read(16)
                    age = struct.unpack('<I', f.read(4))[0]
                    pdb_name = f.read(256).split(b'\x00')[0].decode('utf-8')
                    
                    # 格式化 GUID
                    g = struct.unpack('<IHH8B', guid)
                    guid_str = f"{g[0]:08X}{g[1]:04X}{g[2]:04X}{''.join(f'{x:02X}' for x in g[3:])}"
                    
                    return {
                        "pdb_name": os.path.basename(pdb_name),
                        "guid": guid_str,
                        "age": age,
                        "download_url": f"https://msdl.microsoft.com/download/symbols/{os.path.basename(pdb_name)}/{guid_str}{age:X}/{os.path.basename(pdb_name)}"
                    }
    return None

# 测试
path = r"C:\Windows\System32\ntoskrnl.exe"
info = get_pdb_info(path)
if info:
    print(f"PDB Name: {info['pdb_name']}")
    print(f"GUID:     {info['guid']}")
    print(f"Age:      {info['age']:X}")
    print(f"URL:      {info['download_url']}")


照着写就行 就是文件二进制数据的处理和转换

补充内容 (2026-3-28 11:02):
提取64位系统system32目录里文件的时候调用dll关闭重定向或者用C:\Windows\Sysnative替代
回复

使用道具 举报

结帖率:92% (12/13)

签到天数: 22 天

 楼主| 发表于 昨天 09:45 | 显示全部楼层   安徽省淮北市
对哦,好像32位会重定向目录
回复

使用道具 举报

结帖率:92% (12/13)

签到天数: 22 天

 楼主| 发表于 昨天 11:43 | 显示全部楼层   泛播地址
晶晶易 发表于 2026-3-28 10:59
[mw_shl_code=python,true]import struct
import os

python和c++的我都有办法,就是易语言没办法
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备2025452707号) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表