• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            《Windows via C/C++》中示例程序DIPS的問題

              前一階段重溫了Windows中的HOOK,由此參考了《Windows via C/C++》中的示例程序——DIPS,但是我發(fā)現(xiàn)了一個有趣的問題。
              默認(rèn)情況下,鏈接器并不會將支持XP或Vista的manifest鏈接到程序上,因此,生成的應(yīng)用程序運(yùn)行時的控件風(fēng)格是經(jīng)典Windows樣式,此時,DIPS小工具運(yùn)行正常。
              但是,當(dāng)加上如下這段代碼(適用于x86 CPU),問題就產(chǎn)生了。
            #pragma comment(linker, "/manifestdependency:\"type='win32' name='Microsoft.Windows.Common-Controls' version='6.0.0.0' processorArchitecture='x86' publicKeyToken='6595b64144ccf1df' language='*'\"")
              這意味著鏈接器將會把新的XP或Vista的manifest鏈接到程序上,使應(yīng)用程序具有XP或Vista的控件樣式。這時,問題產(chǎn)生了。
              這里我貼出程序的主函數(shù)代碼:
            int WINAPI _tWinMain(HINSTANCE hInstExe, HINSTANCE, PTSTR pszCmdLine, int{

               
            // Convert command-line character to uppercase.
               CharUpperBuff(pszCmdLine, 1);
               TCHAR cWhatToDo 
            = pszCmdLine[0];

               
            if ((cWhatToDo != TEXT('S')) && (cWhatToDo != TEXT('R'))) {

                  
            // An invalid command-line argument; prompt the user.
                  cWhatToDo = 0;
               }


               
            if (cWhatToDo == 0{
                  
            // No command-line argument was used to tell us what to
                  
            // do; show usage dialog box and prompt the user.
                  switch (DialogBox(hInstExe, MAKEINTRESOURCE(IDD_DIPS), NULL, Dlg_Proc)) {
                     
            case IDC_SAVE:    
                        cWhatToDo 
            = TEXT('S'); 
                        
            break;

                     
            case IDC_RESTORE: 
                        cWhatToDo 
            = TEXT('R');
                        
            break;
                  }

               }


               
            if (cWhatToDo == 0{
                  
            // The user doesn't want to do anything.
                  return(0);
               }

               
               
            // The Desktop ListView window is the grandchild of the ProgMan window.
               HWND hWndLV = GetFirstChild(GetFirstChild(
                  FindWindow(TEXT(
            "ProgMan"), NULL)));
               chASSERT(IsWindow(hWndLV));

               
            // Set hook that injects our DLL into the Explorer's address space. After 
               
            // setting the hook, the DIPS hidden modeless dialog box is created. We 
               
            // send messages to this window to tell it what we want it to do.
               chVERIFY(SetDIPSHook(GetWindowThreadProcessId(hWndLV, NULL)));

               
            // Wait for the DIPS server window to be created.
               MSG msg;
               GetMessage(
            &msg, NULL, 00);      // 請注意這里

               
            // Find the handle of the hidden dialog box window.
               HWND hWndDIPS = FindWindow(NULL, TEXT("Wintellect DIPS"));

               
            // Make sure that the window was created.
               chASSERT(IsWindow(hWndDIPS));

               
            // Tell the DIPS window which ListView window to manipulate
               
            // and whether the items should be saved or restored.
               BOOL bSave = (cWhatToDo == TEXT('S'));
               SendMessage(hWndDIPS, WM_APP, (WPARAM) hWndLV, bSave);

               
            // Tell the DIPS window to destroy itself. Use SendMessage 
               
            // instead of PostMessage so that we know the window is 
               
            // destroyed before the hook is removed.
               SendMessage(hWndDIPS, WM_CLOSE, 00);

               
            // Make sure that the window was destroyed.
               chASSERT(!IsWindow(hWndDIPS));

               
            // Unhook the DLL, removing the DIPS dialog box procedure 
               
            // from the Explorer's address space.
               SetDIPSHook(0);  

               
            return(0);
            }

              看到上面代碼中的GetMessage函數(shù)(加紅色注釋那行),該函數(shù)是在接收一個來自explorer.exe進(jìn)程的消息,這個消息是在掛鉤DLL注入之后,由掛鉤過濾函數(shù)發(fā)送的。掛鉤過濾函數(shù)代碼如下:
            LRESULT WINAPI GetMsgProc(int nCode, WPARAM wParam, LPARAM lParam) {

               
            static BOOL bFirstTime = TRUE;

               
            if (bFirstTime) {
                  
            // The DLL just got injected.
                  bFirstTime = FALSE;

                  
            // Uncomment the line below to invoke the debugger 
                  
            // on the process that just got the injected DLL.
                  
            // ForceDebugBreak();

                  
            // Create the DIPS Server window to handle the client request.
                  CreateDialog(g_hInstDll, MAKEINTRESOURCE(IDD_DIPS), NULL, Dlg_Proc);

                  
            // Tell the DIPS application that the server is up 
                  
            // and ready to handle requests.
                  PostThreadMessage(g_dwThreadIdDIPS, WM_NULL, 00);
               }


               
            return(CallNextHookEx(g_hHook, nCode, wParam, lParam));
            }

              明顯地,這里發(fā)送了一個WM_NULL消息給DIPS進(jìn)程,當(dāng)使用經(jīng)典樣式的控件時一切安好,經(jīng)調(diào)試得到的MSG結(jié)構(gòu)中的各個字段為正確的值。但是加上了上面那行鏈接命令后,調(diào)試得到的MSG結(jié)構(gòu)的字段壓根就不是WM_NULL、0、0,而是一個數(shù)值為49211的消息,這樣導(dǎo)致了DIPS主線程喚醒,隨后的FindWindow可能會返回一個NULL,因為該消息并不是掛鉤過濾函數(shù)的發(fā)送的消息。當(dāng)然,如果在這里Sleep一下,可以得到正確的窗口句柄,我在GetMessage函數(shù)上加了一個do-while循環(huán),結(jié)果也的確是這樣,幾次循環(huán)之后可以收到消息為WM_NULL的消息,且參數(shù)均為0。
              但是我不明白為什么加上了一條鏈接命令會這樣?不妨大家都試試看,我用的IDE是VS2005。
              哪位高手可以來指導(dǎo)我一下呢?

            posted on 2009-06-13 13:37 小虎無憂 閱讀(1793) 評論(3)  編輯 收藏 引用 所屬分類: DLL

            評論

            # re: 《Windows via C/C++》中示例程序DIPS的問題 2009-06-17 17:21 Zxjay

            我也想知道原因  回復(fù)  更多評論   

            # re: 《Windows via C/C++》中示例程序DIPS的問題 2009-06-22 13:45 小虎無憂

            呵呵,樓上的也調(diào)試過了么?是不是我所說的問題啊?  回復(fù)  更多評論   

            # re: 《Windows via C/C++》中示例程序DIPS的問題 2009-06-22 13:45 小虎無憂

            @Zxjay
            呵呵,樓上的也調(diào)試過了么?是不是我所說的問題啊?  回復(fù)  更多評論   

            <2009年5月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導(dǎo)航

            統(tǒng)計

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲国产成人精品女人久久久 | 97精品依人久久久大香线蕉97| 91精品国产91热久久久久福利| 色综合久久久久无码专区| 伊人久久大香线蕉综合Av| 久久久精品久久久久影院| 国产精品久久新婚兰兰| 久久国语露脸国产精品电影| 色婷婷久久综合中文久久蜜桃av| 亚洲精品乱码久久久久久蜜桃图片 | 国产成人综合久久综合| 久久免费线看线看| 久久精品一区二区三区中文字幕 | 亚洲欧美一区二区三区久久| 久久夜色精品国产噜噜亚洲a| 欧美伊人久久大香线蕉综合 | 欧美精品丝袜久久久中文字幕| 色综合久久中文字幕综合网| 久久久久久伊人高潮影院| 国内精品久久久久久99蜜桃| 99久久国产免费福利| 久久精品综合网| 国产精品久久免费| 亚洲欧洲中文日韩久久AV乱码| 7777久久久国产精品消防器材| 韩国三级大全久久网站| 色8激情欧美成人久久综合电| 亚洲女久久久噜噜噜熟女| 精品久久人人做人人爽综合| 久久精品国产精品亚洲精品| 精品久久久久久中文字幕| 亚洲国产精品无码久久青草| 国产精品久久久久9999高清| 亚洲欧美另类日本久久国产真实乱对白| 日韩精品久久无码中文字幕| 欧美精品福利视频一区二区三区久久久精品 | 亚洲国产精品无码久久一区二区 | 日韩一区二区久久久久久 | 99久久99久久精品免费看蜜桃 | 91精品观看91久久久久久| 久久精品国产久精国产果冻传媒|