青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

聚星亭

吾笨笨且懶散兮 急須改之而奮進
posts - 74, comments - 166, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

[轉載] 檢測隱藏進程

Posted on 2009-04-05 17:31 besterChen 閱讀(962) 評論(0)  編輯 收藏 引用 所屬分類: 軟件安全中的JJXX
本人收集與網絡,不知原作者是誰……

一:序言
  下列情況不在討論之中(沒進程)
  1 通過CreateRemoteThread Inject代碼到另一個進程(有種病毒就用這種方法,實現內存感染的;其實還有更多應用)
  2 通過CreateRemoteThread LoadLibray一dll到另一個進程(屏蔽Ctrl+Alt+Del,就是通過這種方法和SetWindowLog實現)


二:進程隱藏
  1 Hook/InlineHook Api NtQuerySystemInformation(taskmgr.exe就是用這個函數得到Process list)
  2 Hook/InlineHook Api Process32Next
  3 把要隱藏的進程的EPROCESS從LIST_ENTRY中摘除
    a)ring0下驅動實現,注意:Nt/2000/xp/2003中PID和FLINK在EPROCESS中的offset不盡相同
    b)ring3下利用call gate結合\Device\PhysicalMemory內核對象實現
 

三:檢測進程隱藏
  我們重要討論一下殺毒軟件Kaspersky和rootkit檢測工具Icesword的兩種方法:
 
  1 kaspersky的方法:kaspersky從6.0中加入了主動防御功能,它detour了SwapContext.

lkd> u KiSwapThread L20
nt!KiSwapThread:
804dd66e 8bff             mov     edi
,edi
804dd670 
56               push    esi
804dd671 
57               push    edi
804dd672 3ea120f0dfff     mov     eax
,ds:[ffdff020]
804dd678 8bf0             mov     esi
,eax
804dd67a 8b4608           mov     eax
,[esi+0x8]
804dd67d 85c0             test    eax
,eax
804dd67f 8b7e04           mov     edi
,[esi+0x4]
804dd682 0f8557ba0000     jne     nt!KiSwapThread+0x16 (804e90df)
804dd688 
53               push    ebx
804dd689 0fbe5e10         movsx   ebx
,byte ptr [esi+0x10]
804dd68d 33d2             xor     edx
,edx
804dd68f 8bcb             mov     ecx
,ebx
804dd691 e86bffffff       call    nt!KiFindReadyThread (804dd601)
804dd696 85c0             test    eax
,eax
804dd698 0f843e990000     je      nt!KiSwapThread+0x2e (804e6fdc)
804dd69e 5b               pop     ebx
804dd69f 8bc8             mov     ecx
,eax
804dd6a1 e80cf7ffff       call    nt!KiSwapContext (804dcdb2)
804dd6a6 84c0             test    al
,al
804dd6a8 8a4f58           mov     cl
,[edi+0x58]
804dd6ab 8b7f54           mov     edi
,[edi+0x54]
804dd6ae 8b3570864d80     mov     esi
,[nt!_imp_KfLowerIrql (804d8670)]
804dd6b4 0f85d10a0100     jne     nt!KiSwapThread+0x56 (804ee18b)
804dd6ba ffd6             call    esi
804dd6bc 8bc7             mov     eax
,edi
804dd6be 5f               pop     edi
804dd6bf 5e               pop     esi
804dd6c0 c3               ret

lkd> u KiSwapContext L20
nt!KiSwapContext:
804dcdb2 83ec10           sub     esp
,0x10
804dcdb5 895c240c         mov     
[esp+0xc],ebx
804dcdb9 
89742408         mov     [esp+0x8],esi
804dcdbd 897c2404         mov     
[esp+0x4],edi
804dcdc1 892c24           mov     
[esp],ebp
804dcdc4 8b1d1cf0dfff     mov     ebx
,[ffdff01c]
804dcdca 8bf1             mov     esi
,ecx
804dcdcc 8bbb24010000     mov     edi
,[ebx+0x124]
804dcdd2 89b324010000     mov     
[ebx+0x124],esi
804dcdd8 8a4f58           mov     cl
,[edi+0x58]
804dcddb e8d9000000       call    nt!SwapContext (804dceb9)
804dcde0 8b2c24           mov     ebp
,[esp]
804dcde3 8b7c2404         mov     edi
,[esp+0x4]
804dcde7 8b742408         mov     esi
,[esp+0x8]
804dcdeb 8b5c240c         mov     ebx
,[esp+0xc]
804dcdef 83c410           add     esp
,0x10
804dcdf2 c3               ret


lkd> u SwapContext L10
nt!SwapContext:
804dceb9 0ac9             or      cl
,cl
804dcebb 26c6462d02       mov     byte ptr es:
[esi+0x2d],0x2
804dcec0 9c               pushfd
804dcec1 8b0b             mov     ecx
,[ebx]
804dcec3 e948cfa077       jmp     f7ee9e10(注意:這個地址不在NTOSKRNL.EXE范圍中
,落在klif.sys范圍中,<它用了相對轉跳,這樣可以節約兩個字節,cs:08>)
804dcec8 
90               nop
804dcec9 
90               nop
804dceca 
51               push    ecx
804dcecb 0f8534010000     jne     nt!SwapContext+0x14d (804dd005)
804dced1 833d8c29568000 cmp dword ptr 
[nt!PPerfGlobalGroupMask (8056298c)],0x0
804dced8 0f85fe000000     jne     nt!SwapContext+0x124 (804dcfdc)
804dcede 0f20c5           mov     ebp
,cr0
804dcee1 8bd5             mov     edx
,ebp
804dcee3 8a4e2c           mov     cl
,[esi+0x2c]
804dcee6 884b50           mov     
[ebx+0x50],cl
804dcee9 fa               cli

考慮到機器的效率,SwapContext是用匯編代碼實現的,看看它具體功能(實現自己看代碼吧:)):
;++
;
; Routine Description:
;
;    This routine is called to swap context from one thread to the next.
;    It swaps context, flushes the data, instruction, and translation
;    buffer caches, restores nonvolatile integer registers, and returns
;    to its caller.
;
;    N.B. It is assumed that the caller (only caller's are within this
;         module) saved the nonvolatile registers, ebx, esi, edi, and
;         ebp. This enables the caller to have more registers available.
;
; Arguments:
;
;    cl - APC interrupt bypass disable (zero enable, nonzero disable).
;    edi - Address of previous thread.
;    esi - Address of next thread.
;    ebx - Address of PCR.
;
; Return value:
;
;    al - Kernel APC pending.
;    ebx - Address of PCR.
;    esi - Address of current thread object.
;
;--

(雖然懸掛或等待的線程,不會獲得cpu時間,但在SwapContext的時候仍然要檢測,知道Thread了,得到對應Process也就容易了)
注:這個方法最初是J. Butler提出的,參見:
http://ieeexplore.ieee.org/xpl/freeabs_all.jsp?arnumber=1232409

 
  2 IceSword的方法:以前的方法是檢測EPRCOESS,后來改成了PspCidTable
  
  a)全局變量PspCidTable是一個HANDLE_TABLE的指針,這個變量并沒有被NTOSKRNL導出,這個HANDLE_TABLE的表保存著所有進程和線程對象的指針.

  b)PID(進程ID)和 ThreadID(線程ID)就是在這個句柄表中的索引,這個HANDLE_TABLE不屬于任何進程,也沒有鏈在HANDLE_TABLE鏈上.

  c)PspCidTable在PsLookupProcessByProcessId中被用到,所以可以在此函數中搜索PspCidTalbe變量以定位其地址.

  d)得到PspCidTable這個句柄表地址后,IceSword調用ExEnumHandleTable.

這個函數的函數原形是:
BOOLEAN ExEnumHandleTable(
IN PHANDLE_TABLE HandleTable,
IN EX_ENUMERATE_HANDLE_ROUTINE EnumHandleProcedure,
IN PVOID EnumParameter,
OUT PHANDLE Handle OPTIONAL)

參數說明:
HandleTable        : 句柄表,可以用PspCidTable做參數.
EnumHandleProcedure: 類型為BOOLEAN (*EX_ENUMERATE_HANDLE_ROUTINE)(HANDLE_TALBE_ENTRY*,DWORD PID,PVOID Param)函數指針.
EnumParameter      : 傳送給EnumHandleProcedure函數的參數.
Handle             : 此函數返回True時此參數才有效,為停止枚舉前所枚舉的句柄(可選).

功能說明:
調用ExEnumHandleTable函數的時,在每次枚舉到表中的一個句柄時都會調用一次回調函數;
回調函數返回值為FALSE時繼續枚舉句柄表,返回TRUE時則停止枚舉.

我們來看看他的具體實現吧!

 

BOOLEAN
ExEnumHandleTable(
    IN PHANDLE_TABLE HandleTable,
    IN EX_ENUMERATE_HANDLE_ROUTINE EnumHandleProcedure,
    IN PVOID EnumParameter,
    OUT PHANDLE Handle OPTIONAL
    )
/*++

Routine Description:

    This function enumerates all the valid handles in a handle table.
    For each valid handle in the handle table, the specified eumeration
    function is called. If the enumeration function returns TRUE, then
    the enumeration is stopped, the current handle is returned to the
    caller via the optional Handle parameter, and this function returns
    TRUE to indicated that the enumeration stopped at a specific handle.

Arguments:

    HandleTable - Supplies a pointer to a handle table.

    EnumHandleProcedure - Supplies a pointer to a fucntion to call for
        each valid handle in the enumerated handle table.

    EnumParameter - Supplies an uninterpreted 32-bit value that is passed
        to the EnumHandleProcedure each time it is called.

    Handle - Supplies an optional pointer a variable that receives the
        Handle value that the enumeration stopped at. Contents of the
        variable only valid if this function returns TRUE.

Return Value:

    If the enumeration stopped at a specific handle, then a value of TRUE
    is returned. Otherwise, a value of FALSE is returned.

--
*/

{

    PHANDLE_ENTRY HandleEntry;
    BOOLEAN ResultValue;
    PHANDLE_ENTRY TableEntries;
    PHANDLE_ENTRY TableBound;
    ULONG TableIndex;

    PAGED_CODE();

    ASSERT(HandleTable 
!= NULL);

    
//
    
// Lock the handle table exclusive and enumerate the handle entries.
    
//

    ResultValue 
= FALSE;
    ExLockHandleTableShared(HandleTable);
    TableBound 
= HandleTable->TableBound;
    TableEntries 
= HandleTable->TableEntries;
    HandleEntry 
= &TableEntries[1];
    
while (HandleEntry < TableBound) {
        
if (ExIsEntryUsed(TableEntries, TableBound, HandleEntry)) {
            TableIndex 
= HandleEntry - TableEntries;
            
if ((*EnumHandleProcedure)(HandleEntry,
                                        INDEX_TO_HANDLE(TableIndex),
                                        EnumParameter)) {

                
if (ARGUMENT_PRESENT(Handle)) {
                    
*Handle = INDEX_TO_HANDLE(TableIndex);
                }

                ResultValue 
= TRUE;
                
break;
            }
        }

        HandleEntry 
+= 1;
    }

    ExUnlockHandleTableShared(HandleTable);
    
return ResultValue;
}


(PS:IceSword的檢測方法部分參見匿名用戶的文章,非常感謝!)

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品国产999大香线蕉| 午夜视频在线观看一区| 免费成人高清在线视频| 亚洲国产精品日韩| 欧美国产欧美亚洲国产日韩mv天天看完整 | 久久三级福利| 免费亚洲一区二区| 亚洲精品一线二线三线无人区| 亚洲高清123| 欧美精品免费在线观看| 亚洲桃花岛网站| 羞羞答答国产精品www一本| 国产一区999| 欧美激情综合色| 欧美日韩另类国产亚洲欧美一级| 小嫩嫩精品导航| 久久亚洲欧美国产精品乐播| 亚洲另类一区二区| 亚洲在线观看视频| 在线观看日韩国产| 制服诱惑一区二区| 激情小说亚洲一区| 亚洲精品社区| 激情偷拍久久| 在线一区二区三区四区| 狠狠色伊人亚洲综合成人| 亚洲激情小视频| 国产综合久久久久久| 亚洲人久久久| 在线观看欧美成人| 亚洲午夜久久久| 亚洲人成网站精品片在线观看| 亚洲主播在线| 一本一本大道香蕉久在线精品| 欧美在线视屏| 亚洲在线网站| 欧美国产亚洲视频| 久久色在线播放| 国产精品乱码| 99精品国产在热久久婷婷| 伊人春色精品| 亚洲欧美日韩直播| 在线中文字幕日韩| 欧美第十八页| 免费日韩成人| 国产一区二区日韩精品| 亚洲视频一区在线| 中文在线资源观看视频网站免费不卡| 久久国产欧美精品| 久久福利资源站| 国产精品久久久久久久久借妻| 亚洲国产精品一区二区第四页av| 国产一区二区三区无遮挡| 亚洲欧美一区二区三区在线| 亚洲午夜一区| 欧美日韩精品在线播放| 亚洲福利视频免费观看| 亚洲成色777777女色窝| 久久蜜桃精品| 免费亚洲一区| 1024成人网色www| 久久久久国产精品人| 久久久久久自在自线| 国产午夜精品美女视频明星a级| 亚洲综合二区| 久久久久国产精品www| 国产午夜精品在线| 欧美在线关看| 久久综合影音| 亚洲黄色在线观看| 欧美激情小视频| 亚洲区免费影片| 日韩午夜免费视频| 欧美四级在线观看| 亚洲视频在线观看三级| 欧美一级理论性理论a| 国产亚洲欧美日韩在线一区| 久久精品中文字幕一区| 欧美成人国产| 一区二区电影免费在线观看| 欧美图区在线视频| 午夜国产不卡在线观看视频| 久久久www成人免费毛片麻豆| 影音先锋亚洲精品| 欧美成人免费网站| 一区二区三区国产在线观看| 欧美一区二区女人| 亚洲国产精品久久91精品| 欧美激情国产高清| 亚洲一区二区黄| 麻豆国产精品va在线观看不卡 | 欧美ed2k| 亚洲一区二区综合| 欧美成人久久| 亚洲尤物视频在线| 在线观看亚洲专区| 欧美日韩国产首页| 性做久久久久久久免费看| 欧美二区在线| 午夜视频一区在线观看| 在线欧美小视频| 国产精品扒开腿做爽爽爽软件| 午夜一区不卡| 亚洲日本理论电影| 久久久精品久久久久| 亚洲作爱视频| 尤物网精品视频| 国产精品vip| 欧美成人国产| 欧美在线你懂的| 日韩视频免费大全中文字幕| 久久久久久久波多野高潮日日| 一区二区电影免费观看| 影音先锋亚洲一区| 国产精品亚洲片夜色在线| 欧美成年人视频| 欧美中文在线字幕| 国产精品99久久久久久久vr| 欧美激情在线免费观看| 久久久久久久久久久久久久一区| 中文精品视频| 日韩一级不卡| 亚洲福利在线观看| 国产网站欧美日韩免费精品在线观看| 欧美区日韩区| 欧美国产欧美综合| 久久久美女艺术照精彩视频福利播放| 亚洲一区二区黄| 宅男噜噜噜66国产日韩在线观看| 欧美高清视频一区二区三区在线观看| 久久av一区二区三区漫画| 亚洲欧美日韩天堂| 亚洲午夜一级| 亚洲一区二区三区免费观看| 亚洲毛片在线| 99ri日韩精品视频| 日韩午夜在线电影| 亚洲毛片av| 99re在线精品| 一本色道久久综合亚洲精品婷婷| 亚洲国产精品精华液网站| 亚洲国产精品视频一区| 亚洲国产精品电影在线观看| 亚洲国产高潮在线观看| 最新国产成人av网站网址麻豆| 亚洲成人在线视频网站| 亚洲激情亚洲| 99精品黄色片免费大全| 中文有码久久| 先锋影音国产精品| 久久高清免费观看| 噜噜噜躁狠狠躁狠狠精品视频| 久久综合狠狠综合久久综合88| 噜噜噜在线观看免费视频日韩| 欧美成人日韩| 亚洲黄色大片| 日韩视频一区| 香蕉久久国产| 久久精品在线免费观看| 免费av成人在线| 欧美日韩亚洲国产精品| 国产精品综合av一区二区国产馆| 国产午夜精品一区二区三区欧美 | 黄色亚洲精品| 99精品欧美一区二区三区| 亚洲一区二区3| 久久精品国产一区二区三| 免费观看一级特黄欧美大片| 亚洲日本aⅴ片在线观看香蕉| 在线午夜精品| 久久久久久一区| 欧美日韩国产一区二区三区| 国产精品剧情在线亚洲| 伊人久久亚洲影院| 亚洲视频一区在线观看| 久久精品国产亚洲高清剧情介绍| 欧美国产一区在线| 亚洲一区二区日本| 老**午夜毛片一区二区三区| 欧美日韩国产成人| 国内精品久久久久久| 99re6热在线精品视频播放速度| 欧美亚洲在线观看| 亚洲国产91精品在线观看| 一本一道久久综合狠狠老精东影业| 性xx色xx综合久久久xx| 欧美日韩不卡| 亚洲电影免费观看高清完整版| 亚洲欧美久久久久一区二区三区| 巨胸喷奶水www久久久免费动漫| 亚洲欧洲日本专区| 久久久国产一区二区| 国产精品久久久久久模特| 最新日韩中文字幕| 久久久久欧美精品| 在线亚洲高清视频| 欧美激情综合网| 狠狠狠色丁香婷婷综合久久五月| 亚洲午夜在线| 亚洲人线精品午夜|