捕获OutputDebugString

 

捕获OutputDebugString 其实这个函数只是在一段共享内存中放入了输出的文本,通过一些同步的内核对象通,调试器根据这些对象就可以得到相应的输出。

 

 

 

下面就是一个简单的程序,它能够获取所有的调试信息输出,如果要获取某个进程的文本输出,需要做一些筛选。

 

#include <Windows.h>
#include <process.h>

#pragma pack(push)
#pragma pack(1)
typedef struct __DEBUGBUFFER
{
	DWORD sz;      //进程id
	char szString[4096 - sizeof(DWORD)];
} DEBUGBUFFER, *PDEBUGBUFFER;
#pragma pack(pop)
;
#define MAX_DEBUG_BUF_LEN (4096)
#define _Try __try
#define _Finally __finally

void aaa(void* p)
{
	
	while(TRUE)
	{
		Sleep(1000);
		OutputDebugStringA("GGGGGGGGG");
	}
}

int _tmain(int argc, _TCHAR* argv[])
{
//	_beginthread(aaa,NULL,0);

	HANDLE m_hReadyEvent;
	DWORD m_dwResult;
	HANDLE hMapping = NULL;
	HANDLE hAckEvent = NULL;
	PDEBUGBUFFER pdbBuffer = NULL;
	//TCHAR tzBuffer[MAX_DEBUG_BUF_LEN];
	_Try
	{
#define _LeaveIf(expr) if(expr == TRUE) \
		return FALSE;
		// 设置初始结果
		m_dwResult = ERROR_INVALID_HANDLE;
		// 打开事件句柄
		hAckEvent = CreateEvent(NULL, FALSE, FALSE, TEXT("DBWIN_BUFFER_READY"));
		_LeaveIf(hAckEvent == NULL);
		m_hReadyEvent = CreateEvent(NULL, FALSE, FALSE, TEXT("DBWIN_DATA_READY"));
		_LeaveIf(m_hReadyEvent == NULL);
		// 创建文件映射
		hMapping = CreateFileMapping(INVALID_HANDLE_VALUE, NULL, PAGE_READWRITE, 0, MAX_DEBUG_BUF_LEN, TEXT("DBWIN_BUFFER"));
		_LeaveIf(hMapping == NULL);
		// 映射调试缓冲区
		pdbBuffer = (PDEBUGBUFFER) MapViewOfFile(hMapping, FILE_MAP_READ, 0, 0, 0);
		_LeaveIf(pdbBuffer == NULL);
		// 循环
		for (m_dwResult = ERROR_SIGNAL_PENDING; (m_dwResult == ERROR_SIGNAL_PENDING); )
		{
			// 等待缓冲区数据
			SetEvent(hAckEvent);
			if (WaitForSingleObject(m_hReadyEvent, INFINITE) == WAIT_OBJECT_0)
			{
				// 如果是继续等待,否则表示主线程发出了停止信号,退出当前线程
				if (m_dwResult == ERROR_SIGNAL_PENDING)
				{ 
					// 添加新项
					printf(pdbBuffer->szString);
				}
			}
			else
			{
				// 等待失败
				m_dwResult = WAIT_ABANDONED;
			}
		}
	}
	_Finally
	{
#define _SafeCloseHandle(handle) if(handle != NULL) \
		CloseHandle(handle);
		// 释放
		if (pdbBuffer)
		{
			UnmapViewOfFile(pdbBuffer);
		}
		_SafeCloseHandle(hMapping);
		_SafeCloseHandle(m_hReadyEvent);
		_SafeCloseHandle(hAckEvent);

		// 返回结果
		return m_dwResult;
	}
}



 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值