0

我想从注入另一个进程的 MFC dll 打开一个 MFC 无模式对话框,该 dll 的工作是挂钩 winsock send & recv,该对话框将是与 dll 通信的接口。dll 应该能够在对话框运行时运行挂钩。

BOOL CDriverApp::InitInstance()
{
    CWinApp::InitInstance();

    if (!AfxSocketInit())
    {
        AfxMessageBox(IDP_SOCKETS_INIT_FAILED);
        return FALSE;
    }

    AfxMessageBox("I'm In!");

    DetourTransactionBegin();
    DetourUpdateThread( GetCurrentThread() );
    DetourAttach( &(PVOID &)RealSend, MySend );
    DetourAttach( &(PVOID &)RealRecv, MyRecv );
    if ((DetourTransactionCommit()) == NO_ERROR)
    {
        AfxMessageBox("Winsock hooked");
    }
    dlg = new ControlDlg();
    m_pMainWnd = dlg;
    if(dlg->Create(IDD_CONTROL_DLG))
    {
        dlg->ShowWindow(SW_SHOW);
    }

    //ExitThread(0);
    return TRUE; <--- 
}

dlg是属于的对话框CDriverApp

根据我的观察,对话框被破坏,因为线程已经退出并且保存对话框的内存被删除。

The thread '_DllMainCRTStartup' (0x418) has exited with code 1657602048 (0x62cd0000).

我已经阅读了MFC 无模式对话框立即关闭线程,但我InitInstance()已经true从一开始就返回了,所以这是一个不同的问题(我认为)

所以,我的问题是如何防止对话框被破坏?或者也许阻止线程退出?还是可以使用模态对话框?

4

1 回答 1

1

这可能是你的问题:

常规 DLL 必须具有 CWinApp 派生类和该应用程序类的单个对象,就像 MFC 应用程序一样。但是,DLL 的 CWinApp 对象没有主消息泵,应用程序的 CWinApp 对象也没有。

请注意,CWinApp::Run 机制不适用于 DLL,因为应用程序拥有主消息泵。如果 DLL 打开无模式对话框或拥有自己的主框架窗口,则应用程序的主消息泵必须调用由 DLL 导出的例程,该例程又调用 DLL 应用程序对象的 CWinApp::PreTranslateMessage 成员函数。

http://msdn.microsoft.com/en-US/library/f22wcbea(v=vs.80 )

编辑:

这显示了如何使用 cWnd 而不是 CDialog 来执行您正在执行的操作。我个人认为这是一个更好的方法。

http://codinganswer.com/c/cwnd-in-a-new-thread-in-a-dll.html

这是将消息挂钩附加到无模式的示例。

http://support.microsoft.com/kb/q187988/

于 2012-06-25T18:29:02.330 回答