WEB开发网
开发学院软件开发VC 在VC++程序中自定义Vista事件日志 阅读

在VC++程序中自定义Vista事件日志

 2010-06-15 20:40:18 来源:WEB开发网   
核心提示:引发事件实际上,在程序中引发事件是相当地简单(至少与定义清单文件相比是这样的),在VC++程序中自定义Vista事件日志(2),正如前面所提到的,消息编译器生成了包含有事件及事件发布者定义的头文件,如果一切正常,事件就会如期出现在日志记录中,这些信息都可传递给SDK函数,对上面的清单文件而言

引发事件

实际上,在程序中引发事件是相当地简单(至少与定义清单文件相比是这样的),正如前面所提到的,消息编译器生成了包含有事件及事件发布者定义的头文件,这些信息都可传递给SDK函数,对上面的清单文件而言,头文件将会包含以下定义:

EXTERN_C __declspec(selectany) const
GUID DOTNETPERFORMANCE_TECHNICALWRITING_PUBLISHER
= {0x9cde86c9, 0xdfb9, 0x463f, {0xb2, 0xc5,0x71,
0xee,0xc2,0x32,0xa6,0x9c}};
#define DOTNETPERFORMANCEOP 0x10
#define DOTNETPERFORMANCEDEBUG 0x0
EXTERN_C __declspec(selectany) const
EVENT_DESCRIPTOR OP_EVENT = {0x1, 0x0,
0x10, 0x4, 0x0, 0x0, 0x8000000000000000};
#define DNP_OP_EVENT_value 0x1
EXTERN_C __declspec(selectany) const
EVENT_DESCRIPTOR DEBUG_EVENT ={0x2, 0x0,
0x0, 0x4, 0x0, 0x0, 0x4000000000000000};
#define DNP_DEBUG_EVENT_value 0x2
#define MSG_SimpleMessage 0xB0000001L

接下来,要在代码中包含以下头文件:windows.h(如果为控制台程序)、evntprov.h(其包含了所有的Windows事件跟踪)、winevt.h(其包含了所有新的Vista日志声明);另外,可通过调用EventRegister来注册事件发布者:

REGHANDLE hPub = NULL;
EventRegister(
&DOTNETPERFORMANCE_TECHNICALWRITING_PUBLISHER,
NULL, NULL, &hPub);

实际上,引发一个事件非常之简单:创建一个事件描述符并把它传递给EventWrite函数就可以了:

EVENT_DATA_DESCRIPTOR opEventDesc;
PWSTR pwsOp = L"My Operational Event";
EventDataDescCreate(&opEventDesc, pwsOp,
((ULONG)wcslen(pwsOp)+1)*sizeof(WCHAR));
EventWrite(hPub, &DNP_OP_EVENT, 1, &opEventDesc);

代码中的宏EventDataDescCreate定义在头文件evntprov.h中,它只是提供了一种更短的语法用于设置变量EVENT_DATA_DESCRIPTOR的成员。

如果不再需要为特定发布者写入事件,可取消注册:

EventUnregister(hPub)

部署及使用

在部署程序之前,还需要使用以下命令来注册清单文件:

wevtutil install-manifest 清单文件名。xml

Windows Vista自带的wevtutil工具,将会解析清单文件并添加所需的设置到Vista日志记录中;如果未运行wevtutil,事件仍可被成功引发,但在事件日志中将不可见。

如果一切正常,事件就会如期出现在日志记录中,如下图。

上一页  1 2 

Tags:VC 程序 定义

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接