• <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>

            Error

            C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
              217 Posts :: 61 Stories :: 32 Comments :: 0 Trackbacks

            // 本質(zhì)上來說就是自己設(shè)置了UnhandleExceptionFilter后,C運行庫或者其他什么別的函數(shù)也調(diào)用了,所以自己設(shè)置的就無效了,解決方案就是HOOK SET函數(shù),讓別人無法取代自己

            很多 C/C++ 程序會設(shè)置自己的 Unhandled Exception Filter 用于捕獲 Unhandled exceptions 并輸出一些信息(例如,創(chuàng)建 mini-dump 或者輸出調(diào)用棧到日志文件中)。

            從 VC++2005 開始出于安全因素微軟改變了 CRT 的行為。在以下情況下 CRT 不會通知被注冊的 Unhandled Exception Filter:

            1. 調(diào)用了 abort() 并且設(shè)置 abort 的行為為 _CALL_REPORTFAULT(Release 版本默認(rèn)使用此設(shè)置)
            2. Security Checks 失敗時,具體來說就是檢查到一些會引發(fā)安全問題的堆棧溢出時不會通知被注冊的 Unhandled Exception Filter,會引發(fā)安全問題的堆棧溢出包括:覆蓋了函數(shù)的返回值,覆蓋了 Exception handler 的地址,覆蓋了某些類型的參數(shù)。關(guān)于編譯器的 Security Checks 的內(nèi)容,詳細(xì)參考:http://msdn.microsoft.com/en-us/library/Aa290051(注意,此文章談到的是 Visual Studio .NET 2003,其中 _set_security_error_handler 函數(shù)在 VC++2005 以及以上版本已經(jīng)無法使用)
            3. 如果沒有調(diào)用 _set_invalid_parameter_handler 設(shè)置 Invalid parameter handler 時,檢查到了非法的參數(shù)

            CRT 是通過何種方式使得我們注冊的 Unhandled Exception Filter 不被調(diào)用的?答案在 CRT 的代碼中:

            1. /* 代碼來源于 gs_report.c */
            2. /* Make sure any filter already in place is deleted. */
            3. SetUnhandledExceptionFilter(NULL);
            4. UnhandledExceptionFilter(&ExceptionPointers);

            CRT 通過調(diào)用 SetUnhandledExceptionFilter 并傳遞參數(shù) NULL 來清除用戶注冊的 Unhandled Exception Filter。如果期望用戶注冊的 Unhandled Exception Filter 總是被調(diào)用那么應(yīng)該避免 CRT 中相關(guān)的清理代碼。做法之一就是修改 CRT 代碼并且編譯為靜態(tài)庫(微軟的 VC++ Libraries 開發(fā) Lead Martyn Lovell 在 https://connect.microsoft.com/feedback/ViewFeedback.aspx?FeedbackID=101337&SiteID=210 談到過有關(guān)的問題),這里并不建議使用此做法。另外一種做法則是改變 SetUnhandledExceptionFilter 的行為,使得 CRT 對 SetUnhandledExceptionFilter 的調(diào)用不起任何作用(更加詳細(xì)的論述可以參考《Windows 核心編程》相關(guān)章節(jié))。

            1. // 無法得知此代碼來源于
            2. #ifndef _M_IX86
            3. #error "The following code only works for x86!"
            4. #endif
            5.  
            6. // 此函數(shù)一旦成功調(diào)用,之后對 SetUnhandledExceptionFilter 的調(diào)用將無效
            7. void DisableSetUnhandledExceptionFilter()
            8. {
            9. void* addr = (void*)GetProcAddress(LoadLibrary("kernel32.dll"),
            10. "SetUnhandledExceptionFilter");
            11.  
            12. if (addr)
            13. {
            14. unsigned char code[16];
            15. int size = 0;
            16.  
            17. code[size++] = 0x33;
            18. code[size++] = 0xC0;
            19. code[size++] = 0xC2;
            20. code[size++] = 0x04;
            21. code[size++] = 0x00;
            22.  
            23. DWORD dwOldFlag, dwTempFlag;
            24. VirtualProtect(addr, size, PAGE_READWRITE, &dwOldFlag);
            25. WriteProcessMemory(GetCurrentProcess(), addr, code, size, NULL);
            26. VirtualProtect(addr, size, dwOldFlag, &dwTempFlag);
            27. }
            28. }

            只需要在注冊 Unhandled Exception Filter 之后調(diào)用 DisableSetUnhandledExceptionFilter() 函數(shù),那么之后所有對 SetUnhandledExceptionFilter 的調(diào)用都將無效,自然 CRT 也無法通過調(diào)用 SetUnhandledExceptionFilter 來清除用戶注冊的 Unhandled Exception Filter。

            posted on 2015-05-15 02:17 Enic 閱讀(2622) 評論(0)  編輯 收藏 引用 所屬分類: 從零開始寫棋牌游戲平臺
            久久狠狠高潮亚洲精品| 久久笫一福利免费导航| 国产aⅴ激情无码久久| 草草久久久无码国产专区| 色欲综合久久中文字幕网| 婷婷久久精品国产| 无码人妻少妇久久中文字幕| 人人狠狠综合久久亚洲| 久久最新免费视频| 怡红院日本一道日本久久| 久久夜色tv网站| 精品无码久久久久久久久久| 国内精品久久久久久久影视麻豆 | 中文字幕成人精品久久不卡| 国产精品久久网| 久久国产精品一区| 亚洲午夜精品久久久久久浪潮| 久久人人爽人人爽人人片AV麻豆| 久久99久久无码毛片一区二区| 欧美国产成人久久精品| 亚洲欧美日韩久久精品第一区| 久久久精品2019免费观看| 久久精品国产精品亚洲精品| 久久人妻少妇嫩草AV蜜桃| 伊人久久综合无码成人网| 久久99热只有频精品8| 精品久久久无码中文字幕| 大香伊人久久精品一区二区| 久久精品亚洲日本波多野结衣| 久久久青草青青亚洲国产免观| 色综合久久天天综线观看| 久久久久人妻一区精品性色av| 国产成人久久777777| 国产精品久久久久久久app| 久久夜色精品国产噜噜亚洲AV| 国产精品成人99久久久久| 久久婷婷五月综合国产尤物app| 99久久国产综合精品麻豆| 一97日本道伊人久久综合影院| 久久精品黄AA片一区二区三区| 久久久精品人妻无码专区不卡|