<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
ETW(Event Tracing for Windows)提供了一種對使用者層應用程式和核心層驅動建立的事件物件的跟蹤記錄機制。為開發者提供了一套快速、可靠、通用的一系列事件跟蹤特性。
一直想研究一種監控程序的方法,但wmi/列舉程序的方法,要麼反應太慢,要麼佔用高。最近看到有人用易語言易語言完成了Etw對程序變動監控的實現。
但是一直沒看到C++的實現,於是決定將易語言易語言翻譯為C++。
直接上翻譯的程式碼
#include <iostream> #include <string> #include <cstring> #include <windows.h> #include <evntrace.h> #include <psapi.h> #include <direct.h> #include <evntcons.h> using namespace std; char SESSION_NAME_FILE[] = "Sample_Process"; const UCHAR _Flag[] = { 173, 74, 129, 158, 4, 50, 210, 17, 154, 130, 0, 96, 8, 168, 105, 57 }; EVENT_TRACE_PROPERTIES m_TraceConfig; UCHAR m_pTraceConfig[2048]; char m_File[256]; BOOL m_DoWhile; TRACEHANDLE m_hTraceHandle; ULONG64 m_hTraceHandle_econt[1]; TRACEHANDLE m_hSessionHandle; string Unicode_To_Ansi(wstring strValue) { static CHAR sBuff[1024] = { 0 }; int iRet = WideCharToMultiByte(CP_ACP, 0, strValue.c_str(), -1, sBuff, sizeof(sBuff), NULL, NULL); if (iRet > 0) { return string(sBuff); } return ""; } VOID WINAPI MyProcessRecordEvents(PEVENT_RECORD EventRecord) { switch (EventRecord->EventHeader.EventDescriptor.Id) { case 1://建立程序 cout << "建立程序!進行建立進行的程序ID:" << EventRecord->EventHeader.ProcessId << ",執行緒ID:" << EventRecord->EventHeader.ThreadId << ",程序SessionID:" << *(ULONG*)(((PUCHAR)EventRecord->UserData)+32)<< ",建立的程序ID:"<< *(ULONG*)(((PUCHAR)EventRecord->UserData) + 0) << ",建立的程序路徑:"<< Unicode_To_Ansi( wstring((wchar_t*)(((PUCHAR)EventRecord->UserData) + 60))) <<endl; break; case 2://程序退出 cout << "程序退出!程序ID:" << EventRecord->EventHeader.ProcessId << ",執行緒ID:" << EventRecord->EventHeader.ThreadId << ", 程序名:"<< ((LPSTR)EventRecord->UserData) + 84 <<endl; break; cout << "程序ID:" << EventRecord->EventHeader.ProcessId << ",未知的行為:0x"<<hex<<EventRecord->EventHeader.EventDescriptor.Id << endl; default: break; } } void CloseEtw() { ULONG l_result = StopTraceA(m_hSessionHandle, SESSION_NAME_FILE, (PEVENT_TRACE_PROPERTIES)(m_pTraceConfig + 8)); if (m_hTraceHandle != NULL) { CloseTrace(m_hTraceHandle); } } DWORD WINAPI OpenEtw(LPVOID lpThreadParameter) { m_DoWhile = TRUE; _getcwd(m_File, sizeof(m_File)); strcat(m_File, "\MyFile.etl"); m_TraceConfig.Wnode.BufferSize = 1024; m_TraceConfig.Wnode.Flags = WNODE_FLAG_TRACED_GUID; m_TraceConfig.Wnode.ClientContext = 3; m_TraceConfig.BufferSize = 1; m_TraceConfig.MinimumBuffers = 16; m_TraceConfig.LogFileMode = EVENT_TRACE_REAL_TIME_MODE; m_TraceConfig.LoggerNameOffset = 120; m_TraceConfig.FlushTimer = 1; RtlMoveMemory(m_pTraceConfig + 8, &m_TraceConfig, 120); RtlCopyMemory(m_pTraceConfig + 128, SESSION_NAME_FILE, sizeof(SESSION_NAME_FILE)); RtlCopyMemory(m_pTraceConfig + 128 + sizeof(SESSION_NAME_FILE), m_File, strlen(m_File)); RtlCopyMemory(m_pTraceConfig + 28, _Flag, sizeof(_Flag)); ULONG l_result = StartTraceA(&m_hSessionHandle, SESSION_NAME_FILE, (PEVENT_TRACE_PROPERTIES)(m_pTraceConfig + 8)); if (m_hSessionHandle == NULL && l_result == ERROR_ACCESS_DENIED) { cout << "StartTraceA失敗!原因:無管理員許可權!" << endl; return 0; } else if (m_hSessionHandle == NULL && l_result == ERROR_ALREADY_EXISTS) { m_hSessionHandle = 44;//輸入上一次終止時候的控制程式碼 CloseEtw(); cout << "StartTraceA失敗!原因:已經有Etw事件進行資料跟蹤!請使用上方遮蔽程式碼關閉事件或者使用 計算機管理 停用事件:Sample_Process" << endl; ControlTraceA(m_hSessionHandle, SESSION_NAME_FILE, (PEVENT_TRACE_PROPERTIES)(m_pTraceConfig + 8), 1); return 0; } cout << "hSessionHandle: " << m_hSessionHandle << endl; const UCHAR m_ProcessGUID[] = { 214, 44, 251, 34, 123, 14, 43, 66, 160, 199, 47, 173, 31, 208, 231, 22 }; // PsProvGuid l_result = EnableTraceEx((LPCGUID)(m_ProcessGUID), 0, m_hSessionHandle, 1, 0, 16, 0, 0, 0); //這裡MatchAnyKeyword的64其實是0x40,表示 #KERNEL_KEYWORDS_IMAGE EVENT_TRACE_LOGFILEA m_Logfile; ZeroMemory(&m_Logfile, sizeof(m_Logfile)); m_Logfile.LoggerName = SESSION_NAME_FILE; *((ULONG*)((PUCHAR)&m_Logfile + 20)) = 268439808; m_Logfile.EventRecordCallback = MyProcessRecordEvents; m_Logfile.Context = (PVOID)0x114514;//隨便輸入一個數就好了 SetLastError(0); m_hTraceHandle = OpenTraceA(&m_Logfile); cout << "開始監視!" << endl; m_hTraceHandle_econt[0] = m_hTraceHandle; ULONG rc = ProcessTrace(m_hTraceHandle_econt, 1, 0, 0); return 0; } int main() { CreateThread(NULL, NULL, OpenEtw, NULL, NULL, NULL); //Sleep(10000); system("pause"); CloseEtw(); return 0; }
注意事項
必須給管理員許可權
請正常退出(按任意鍵),否則Trace不會自己關
以上就是C++實現ETW進行程序變動監控詳解的詳細內容,更多關於C++程序監控的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45