• <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>
            posts - 101,  comments - 57,  trackbacks - 0

                     以前看某些文章的時候,知道可以利用“活動進程鏈”隱藏或者檢測進程。對于如何定位活動進程鏈一直沒搞清楚,在看Rootkit那本書上說,通過PsGetCurrentProcess函數可以獲得EPROCESS,但是書中解釋的很模糊,一直沒看明白。
            今天利用WinDbg查看了各個結構,終于把疑問搞清楚了。
            PsGetCurrentProcessº¯Êý·´»ã±àºóÊÇÕâÑù£º
            lkd> u nt!PsGetCurrentProcess
            nt!PsGetCurrentProcess:
            8052b52c 64a124010000         mov          eax,dword ptr fs:[00000124h]
            8052b532 8b4044                   mov          eax,dword ptr [eax+44h]
            8052b535 c3                          ret

            ÔÚÓû§Ä£Ê½Ï£¬FSÖ¸ÏòTEB½á¹¹£¬¶øÔÚÄÚºËģʽÏÂFSÈ´Ö¸ÏòKPCR£¨Kernel's Processor Control Region£©½á¹¹¡£ÄÇô¿ÉÒÔ¿´µ½FS:[0x120]´¦¾ÍÊÇKPRCB£¨Kernel's Processor Cotrol Block£©½á¹¹£¨¿´ÏÂͼºìÉ«¸ßÁÁ´¦£©
            lkd> dt nt!_kpcr
            nt!_KPCR
                    +0x000 NtTib                 : _NT_TIB
                    +0x01c SelfPcr               : Ptr32 _KPCR
                    +0x020 Prcb                  : Ptr32 _KPRCB
                    +0x024 Irql                  : UChar
                    +0x028 IRR                   : Uint4B
                    +0x02c IrrActive             : Uint4B
                    +0x030 IDR                   : Uint4B
                    +0x034 KdVersionBlock        : Ptr32 Void
                    +0x038 IDT                   : Ptr32 _KIDTENTRY
                    +0x03c GDT                   : Ptr32 _KGDTENTRY
                    +0x040 TSS                   : Ptr32 _KTSS
                    +0x044 MajorVersion          : Uint2B
                    +0x046 MinorVersion          : Uint2B
                    +0x048 SetMember             : Uint4B
                    +0x04c StallScaleFactor : Uint4B
                    +0x050 DebugActive           : UChar
                    +0x051 Number                : UChar
                    +0x052 Spare0                : UChar
                    +0x053 SecondLevelCacheAssociativity : UChar
                    +0x054 VdmAlert              : Uint4B
                    +0x058 KernelReserved        : [14] Uint4B
                    +0x090 SecondLevelCacheSize : Uint4B
                    +0x094 HalReserved           : [16] Uint4B
                    +0x0d4 InterruptMode         : Uint4B
                    +0x0d8 Spare1                : UChar
                    +0x0dc KernelReserved2       : [17] Uint4B
               +0x120 PrcbData              : _KPRCB
            Õ¹¿ªKPRCB½á¹¹¼ÌÐø¹Û²ì¿ÉÒÔ¿´µ½FS:[0x124]Ö¸ÏòÁËKTHREAD½á¹¹
            lkd> dt nt!_kprcb
            nt!_KPRCB
                    +0x000 MinorVersion          : Uint2B
                    +0x002 MajorVersion          : Uint2B
               +0x004 CurrentThread         : Ptr32 _KTHREAD
                    +0x008 NextThread            : Ptr32 _KTHREAD
                    +0x00c IdleThread            : Ptr32 _KTHREAD
            ......本結構更多成員省略

            繼續查看KTHREAD結構可以看到KTHREAD+0x44處成員就是KPROCESS指針

            lkd> dt nt!_kthread -v -r
            Matched nt!_KTHREAD
            nt!_KTHREAD
            struct _KTHREAD, 73 elements, 0x1c0 bytes
                    +0x000 Header                : struct _DISPATCHER_HEADER, 6 elements, 0x10 bytes
                       +0x000 Type                  : UChar
                       +0x001 Absolute              : UChar
                       +0x002 Size                  : UChar
                       +0x003 Inserted              : UChar
                       +0x004 SignalState           : Int4B
                       +0x008 WaitListHead          : struct _LIST_ENTRY, 2 elements, 0x8 bytes
                          +0x000 Flink                 : Ptr32 to struct _LIST_ENTRY, 2 elements, 0x8 bytes
                          +0x004 Blink                 : Ptr32 to struct _LIST_ENTRY, 2 elements, 0x8 bytes
                    +0x010 MutantListHead        : struct _LIST_ENTRY, 2 elements, 0x8 bytes
                       +0x000 Flink                 : Ptr32 to struct _LIST_ENTRY, 2 elements, 0x8 bytes
                          +0x000 Flink                 : Ptr32 to struct _LIST_ENTRY, 2 elements, 0x8 bytes
                          +0x004 Blink                 : Ptr32 to struct _LIST_ENTRY, 2 elements, 0x8 bytes
                       +0x004 Blink                 : Ptr32 to struct _LIST_ENTRY, 2 elements, 0x8 bytes
                          +0x000 Flink                 : Ptr32 to struct _LIST_ENTRY, 2 elements, 0x8 bytes
                          +0x004 Blink                 : Ptr32 to struct _LIST_ENTRY, 2 elements, 0x8 bytes
                    +0x018 InitialStack          : Ptr32 to Void
                    +0x01c StackLimit            : Ptr32 to Void
                    +0x020 Teb                   : Ptr32 to Void
                    +0x024 TlsArray              : Ptr32 to Void
                    +0x028 KernelStack           : Ptr32 to Void
                    +0x02c DebugActive           : UChar
                    +0x02d State                 : UChar
                    +0x02e Alerted               : [2] UChar
                    +0x030 Iopl                  : UChar
                    +0x031 NpxState              : UChar
                    +0x032 Saturation            : Char
                    +0x033 Priority              : Char
              +0x034 ApcState              : struct _KAPC_STATE, 5 elements, 0x18 bytes
                       +0x000 ApcListHead           : [2] struct _LIST_ENTRY, 2 elements, 0x8 bytes
                          +0x000 Flink                 : Ptr32 to struct _LIST_ENTRY, 2 elements, 0x8 bytes
                          +0x004 Blink                 : Ptr32 to struct _LIST_ENTRY, 2 elements, 0x8 bytes
                  +0x010 Process               : Ptr32 to struct _KPROCESS, 29 elements, 0x6c bytes

            至此,我們已經搞清了PsGetCurrentProcess的流程
            通過查DDK DOC發現MS對PsGetCurrentProcess函數是這樣描述的:
            PsGetCurrentProcess returns a pointer to the process of the current thread.
            PEPROCESS
                   PsGetCurrentProcess(
                     );
            該函數的返回值是EPROCESS指針。但是我們分析的結果是函數的返回值是KPROCESS的指針。
            這樣的話難道PsGetCurrentProcess 函數返回值既是EPROCESS的指針又是KPROCESS的指針?
            帶著疑問我們繼續往下看:
            lkd> dt nt!_eprocess
            nt!_EPROCESS
               +0x000 Pcb                   : _KPROCESS
                    +0x06c ProcessLock           : _EX_PUSH_LOCK
                    +0x070 CreateTime            : _LARGE_INTEGER
                    +0x078 ExitTime              : _LARGE_INTEGER
                    +0x080 RundownProtect        : _EX_RUNDOWN_REF
               +0x084 UniqueProcessId       : Ptr32 Void
                    +0x088 ActiveProcessLinks : _LIST_ENTRY
            可以看到EPROCESS的第一個成員就是KPROCESS,這樣我們就明白了為什么PsGetCurrentProcess 函數返回值既是EPROCESS的地址又是KPROCESS的地址了。在EPROCESS偏移0x84是進程的PID,偏移0x88(我的系統是XP SP2)就是我們要找的活動進程鏈了。
            以上是我今天學習的一些收獲,如果大家認為有哪些不對的地方,請指正。 

            posted on 2007-08-24 09:25 margin 閱讀(1320) 評論(0)  編輯 收藏 引用
            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            常用鏈接

            留言簿

            隨筆檔案

            文章分類

            文章檔案

            收藏夾

            常去的壇子

            • CVC電腦病毒論壇
            • 很多人說我是AV,我告訴他們:別瞧不起人,我們也能創造價值
            • 安全焦點
            • 黑客聚集的地方,一般是好酒最多的地方...
            • 看雪論壇
            • 國內最強的加密解密論壇,成醉其中經常夜不歸宿
            • 驅動開發論壇
            • 厭倦了啤的朋友們,來我們來整點白的...痛痛快快的BSOD也好過隔鞋瘙癢!

            我的朋友

            • Sen的blog
            • IDE方面資深的受害者...經常為一個變量的定義找不著北的痛苦程序員(深表同情)
            • 老羅的blog
            • 良師益友,千年水牛,引擎猛男,分析怪獸,墨鏡酷哥,臺球高手....

            搜索

            •  

            最新評論

            蜜臀久久99精品久久久久久小说| 国产精品狼人久久久久影院 | 99国产精品久久| 欧美一区二区精品久久| 久久久久久久综合日本| 国产精品久久久久久久app| 人妻无码中文久久久久专区| 97久久精品人人做人人爽| 精品久久亚洲中文无码| 精品久久久久久久久久中文字幕| 久久人人添人人爽添人人片牛牛| 久久青草国产手机看片福利盒子| 青青热久久国产久精品| 久久成人国产精品二三区| 国产69精品久久久久久人妻精品| 精品99久久aaa一级毛片| 久久亚洲春色中文字幕久久久| 久久久精品人妻无码专区不卡| 国产精品无码久久久久久| 久久久国产打桩机| 欧美大战日韩91综合一区婷婷久久青草| 麻豆亚洲AV永久无码精品久久| 久久久久18| 国产真实乱对白精彩久久| 久久青青草原综合伊人| 久久九九精品99国产精品| 亚洲精品美女久久久久99| 区久久AAA片69亚洲| 久久久久久免费视频| 久久亚洲精品无码观看不卡| 精品久久人人做人人爽综合| 国产成人精品久久免费动漫| 久久国产精品无码一区二区三区 | 亚洲日本va午夜中文字幕久久 | 国产高清国内精品福利99久久| 亚洲国产精品无码久久久蜜芽| 亚洲AV无码1区2区久久| 亚洲AV日韩精品久久久久久| 国产亚洲欧美精品久久久| 久久精品无码午夜福利理论片| 久久99国产综合精品|