• <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 閱讀(1309) 評論(0)  編輯 收藏 引用
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿

            隨筆檔案

            文章分類

            文章檔案

            收藏夾

            常去的壇子

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

            我的朋友

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

            搜索

            •  

            最新評論

            国内精品伊人久久久久av一坑| www.久久热.com| 久久九九久精品国产免费直播| 人妻精品久久无码专区精东影业 | 色天使久久综合网天天| 亚洲αv久久久噜噜噜噜噜| 国产精品久久久福利| 久久精品国产亚洲Aⅴ香蕉| 久久香蕉超碰97国产精品| 岛国搬运www久久| 久久A级毛片免费观看| 一97日本道伊人久久综合影院| 久久精品亚洲中文字幕无码麻豆| 久久99精品久久久久久水蜜桃| 亚洲va久久久噜噜噜久久狠狠| 91精品久久久久久无码| 久久精品a亚洲国产v高清不卡| 亚洲国产香蕉人人爽成AV片久久 | 麻豆一区二区99久久久久| 亚洲精品tv久久久久久久久久| 久久国产精品-国产精品| 国产亚洲精品美女久久久| 久久婷婷午色综合夜啪| 久久久久久极精品久久久| 国产亚洲精久久久久久无码AV| 国产精品久久久久久| 久久婷婷五月综合97色| 99久久99久久精品国产片果冻 | 亚洲人AV永久一区二区三区久久| 久久综合九色综合欧美狠狠| 日韩久久久久久中文人妻| 久久无码人妻一区二区三区午夜| 久久精品国产免费观看三人同眠| 久久久久久噜噜精品免费直播 | 天天综合久久久网| 欧美日韩中文字幕久久伊人| 国产精品一久久香蕉国产线看| 少妇人妻88久久中文字幕| 久久久免费精品re6| 久久国产精品-国产精品| 久久99精品九九九久久婷婷|