首页
社区
课程
招聘
[下载]符号文件观察器——SymView[附源码]
发表于: 2012-4-15 18:56 11845

[下载]符号文件观察器——SymView[附源码]

2012-4-15 18:56
11845
符号文件是调试器工作的重要依据,对很多调试功能都起着重要作用,例如栈回溯、源代码级跟踪、变量观察等等。符号文件大多是二进制的,而且不同编译器使用的文件格式有所不同。

SymView工具用来显示符号文件中包含的符号表和符号数据。目前支持微软的Visual C/C++和C#编译器产生的DBG格式的符号文件和PDB格式的符号文件。

SymView提供了以下多种方式来查看或者搜索符号文件的内容:

符号表 PDB或DBG文件中可以包含6种符号表,分别为符号表、源文件表、节贡献表、段表、注入源代码表和帧数据表。
编译素材(Compiland) 用于产生可执行文件的各种素材文件,包括OBJ、DLL、RES等。
数据流 比如描述FPO的FPO数据流。
符号类标(Tag) 根据所描述对象,符号被分为函数、常量、用户定义类型(UDT)、类型、常量等30多个类型。
搜索 可以按照符号逻辑关系或者符号名称等搜索符号。
下图是SymView的一个截图,左侧提供了上面介绍的5种观察视图。右侧上方的网格窗口用于显示左侧选中表格或者符号类的所有数据行或者符号。右侧下方用于显示上方选中行的子符号或者相关信息(属性)。 例如,目前使用的符号类表视图,选中的是UDT类型,右侧上方显示的是目前符号文件(NT内核的公共符号文件)中的所有UDT类型的符号。右侧下方显示的是上方选中的_DBGKD_BREAKPOINTEX类型的所有属性。
如下图:



最下方的窗口用户显示SymView程序自身的调试信息,可能包含它工作过程中遇到的异常或者错误情况。

安装方法
目前,SymView只由一个文件组成,即SymView.exe。只要通过下面的链接下载压缩包后,将其中的文件解压缩到你喜欢的位置就可以了。

值得说明的是,SymView是基于微软的DIASDK开发的,在工作时,它需要系统中已经有DIASDK的COM组件存在。如果你的系统中安装了Visual Studio 2005或者更高的版本的,那么这个组件应该已经安装好了。否则的话,你需要下载msdia80.dll并在命令行窗口执行如下命令进行注册:
regsvr32 msdia80.dll
应该在msdia80.dll所在目录中执行以上命令,或者指定完整的路径。

内部实现
SymView是基于微软的DIASDK开发的。DIASDK是Debug Interface Access SDK的简称。以Visual Studio 2005为例,DIASDK默认被安装在如下目录中:
c:\Program Files\Microsoft Visual Studio 8\DIA SDK

使用DIA组件的方法与使用其它COM组件一样,先要初始化COM支持库,然后创建接口的实例,即:






hr = CoInitialize(NULL);	// Obtain Access To The Provider	hr = CoCreateInstance(__uuidof(DiaSource),//CLSID_DiaSource, 				NULL, 				
CLSCTX_INPROC_SERVER, 				__uuidof(IDiaDataSource),				(void **) &m_pDiaDataSource);	if(hr != S_OK)	{		Msg(L"CoCreateInstance failed - HRESULT = %x\n",hr);		return hr;	}





描述符号的主要接口是IDiaSymbol,它有上百个属性,对应于不同的符号信息。MSDN中描述了DIA接口,尽管不够详尽,但是涵盖了几乎所有接口。
如何编译源代码
如果你希望自己重新编译SymView程序,那么可以通过下面的链接下载源程序包。下载后解压到一个名为SymView的目录中。

尽管包中的项目文件是VC6格式的,但是转化成更高版本的VC编译器然后编译应该不是大问题。

值得注意的是,因为SymView是基于Dia SDK构建的,所以在编译时需要DIASDK的头文件和LIB文件,目前项目文件中是假定DIA SDK是位于当前项目的上一级目录的,即:

DIASDK
--include
--lib
SymView
--*.cpp
--symview.dsw
--...

所以一种简单的方法就是将DIASDK复制一份到与SymView平行的目录,不然的话需要调整项目设置,使其可以找到DIASDK的文件。

附件下载
包含SymView.exe的压缩包(216KB)
包含msdia80.dll的压缩包(639KB)msdia80.zip
SymView程序的完整源代码(358KB)symv_src.zip

[峰会]看雪.第八届安全开发者峰会10月23日上海龙之梦大酒店举办!

上传的附件:
收藏
免费 7
支持
分享
最新回复 (12)
雪    币: 122
活跃值: (72)
能力值: ( LV3,RANK:30 )
在线值:
发帖
回帖
粉丝
2
自己先顶一下。
2012-4-15 20:17
0
雪    币: 297
活跃值: (265)
能力值: ( LV4,RANK:55 )
在线值:
发帖
回帖
粉丝
3
支持 mark
2012-4-15 22:29
0
雪    币: 107
活跃值: (361)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
4
新版本???和张奎银的有什么区别??
2012-4-16 11:22
0
雪    币: 4560
活跃值: (997)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
5
不错收藏了
2012-4-16 12:50
0
雪    币: 58
活跃值: (1090)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
6
MARK 一下,是个好东西!
2012-4-16 13:30
0
雪    币: 300
活跃值: (179)
能力值: ( LV7,RANK:100 )
在线值:
发帖
回帖
粉丝
7
给你个精华!!!!
2012-4-16 14:16
0
雪    币: 248
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
8
HRESULT = 80040154
2012-4-16 14:22
0
雪    币: 122
活跃值: (72)
能力值: ( LV3,RANK:30 )
在线值:
发帖
回帖
粉丝
9
2012-4-17 09:30
0
雪    币: 309
活跃值: (83)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
10
好东西,感谢分享
2012-4-17 09:54
0
雪    币: 111
活跃值: (35)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
11
源代码不全吧,少个dlgprocess文件
2012-4-17 15:53
0
雪    币: 175
活跃值: (2421)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
12
是个好东西!
2012-4-30 15:38
0
雪    币: 9
活跃值: (175)
能力值: ( LV6,RANK:90 )
在线值:
发帖
回帖
粉丝
13
HRESULT = 80040154
2019-5-14 20:30
0
游客
登录 | 注册 方可回帖
返回
//