程序的执行步骤设计如下:
1、编写一个窗体消息挂接DLL,这个DLL提供一个,函数中利用setwindowlong函数将窗体的默认消息处理过程改为这个挂接DLL中定义的一个窗体过程。
2、在C#程序中利用findwindow等API函数获得exlore类窗体的句柄及窗体所属的进程,并使用performcallback4在目标进程空间中执行coredll.dll的loadLibrary函数将我们写的挂接dll放到目标进程中。
3、在C#程序中使用performcallback4在目标进程空间中执行挂接DLL提供的导出接口函数实现跨进程窗体消息截获.
一、程序的实现如下:
在VS2005中建立一个智能设备的MFC DLL,命名为HookWindowsProcMFCDLL。
在HookWindowsProcMFCDLL.cpp中进行挂接DLL的核心编码:
LRESULT CALLBACK fnHookWindowProc(HWND hwnd,UINT msg,WPARAM wparam, LPARAM lparam);
int __declspec(dllexport) WINAPI fnAttachWinProc(HWND ni_hAttatchWin,PVOID ,PVOID,PVOID);
int __declspec(dllexport) WINAPI fnDetachWinMsgProc(HWND ni_hDetachWin);
WNDPROC tpOldWindowProc;
FILE *m_pDebugOutputFile;
//将一个窗体消息处理挂接到net精简版MessageWindow对象上的代码 typedef struct { WNDPROC OldWinProc;//保留窗体原始消息处理过程的函数指针 HWND WindowHandle;//保存net精简版中对应的窗口挂接的MessageWindow对象的句柄 } DEFUDT_AttachWinInfo; //end struct
CMap m_aAttachWinInfoMap;
//对指定的窗口进程进行挂接 int __declspec(dllexport) WINAPI fnAttachWinProc(HWND ni_hAttatchWin, PVOID ni_0, PVOID ni_1, PVOID ni_2 ) { DEFUDT_AttachWinInfo tudtAttachWinInfo; m_pDebugOutputFile = fopen("\\Storage Card\\WinProcInfo.txt", "w"); WNDPROC tpOldWindowProc=(WNDPROC)::SetWindowLong(ni_hAttatchWin, GWL_WNDPROC,(LONG) fnHookWindowProc ); fprintf(m_pDebugOutputFile,"Attatch successfully! OldWindowProc: X\n",tpOldWindowProc); tudtAttachWinInfo.OldWinProc=tpOldWindowProc ; tudtAttachWinInfo.WindowHandle=ni_hAttatchWin; m_aAttachWinInfoMap.SetAt(ni_hAttatchWin,tudtAttachWinInfo); fclose(m_pDebugOutputFile); return 77;// (int)tpOldWindowProc ; }//end function
int __declspec(dllexport) WINAPI fnDetachWinMsgProc(HWND ni_hDetachWin) { DEFUDT_AttachWinInfo tudtAttachWinInfo; WNDPROC tpOldWindowProc;
//取得在ncf中消息接收窗口对应的原始消息处理函数的函数指针 m_aAttachWinInfoMap.Lookup(ni_hDetachWin,tudtAttachWinInfo) ;
//将窗体的消息处理函数设为默认的处理过程 tpOldWindowProc =(WNDPROC) SetWindowLong(ni_hDetachWin,GWL_WNDPROC , (LONG)tudtAttachWinInfo.OldWinProc);
//将挂接信息消息处理映谢类中删除 m_aAttachWinInfoMap.RemoveKey(ni_hDetachWin);
return (int)tpOldWindowProc ;
}//end function
LRESULT CALLBACK fnHookWindowProc(HWND hwnd,UINT msg,WPARAM wparam, LPARAM lparam) { DEFUDT_AttachWinInfo tudtAttachWinInfo; m_aAttachWinInfoMap.Lookup(hwnd,tudtAttachWinInfo) ; m_pDebugOutputFile = fopen("\\Storage Card\\WinProcInfo.txt", "a"); if (m_pDebugOutputFile!=NULL) { fprintf(m_pDebugOutputFile,"HWND: X Msg: X Wparam X Lparam X \n", hwnd,msg,wparam,lparam);
}//EHD IF
fclose(m_pDebugOutputFile); //tudtAttachWin=maatt LRESULT tobjResult= ::CallWindowProc(tudtAttachWinInfo.OldWinProc ,hwnd,msg,wparam,lparam); return tobjResult; }//end function |
下一篇:软件知识讨论:PHPer为什么被认为是草根?  推荐:PHP 5.0对象模型深度探索
开篇注释:以下文字并没有非常多的技术词汇,所以只要对PHP感兴趣的人都可以看看。
PHPer是草根吗?
从PHP诞生之日起,PHP就开始在Web应用方面为广大的程序员服务。同时,作为针对Web开发量身定制的脚本语言,PHP一直秉承简单、...[查看详情] |