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

最近期末答辯不知道寫(xiě)什么好,就寫(xiě)一個(gè)安全軟件吧。軟件使用驅(qū)動(dòng)和C++編寫(xiě),大概多數(shù)安全軟件都是這樣吧。
時(shí)間關(guān)系,就不說(shuō)那么多了,直接入正題吧。
在此先感謝“伊麗_殺_白”、“墮落天才”、“antirootkit”等提供的優(yōu)秀文章,我只是在他們基礎(chǔ)之上修改了一下。

伊麗_殺_白    暴力搜索內(nèi)存空間檢測(cè)隱藏進(jìn)程:http://bbs.xdnice.com/thread-377796-1-1.html

墮落天才        ring0檢測(cè)隱藏進(jìn)程:http://bbs.pediy.com/showthread.php?t=44243

antirootkit        枚舉隱藏進(jìn)程for ring0(搜索內(nèi)存大法):http://hi.baidu.com/antirootkit/blog/item/d2314b5c94772040fbf2c00b.html

原理:
大概流程圖如下,當(dāng)然我修改了部分。




下面看代碼吧,沒(méi)時(shí)間了,等下十點(diǎn)還要上課,有不明白的可以留言。我會(huì)解答的。
 
不過(guò)這種方法還是很容易躲過(guò),詳細(xì)就不公布出來(lái)了,看來(lái)還是要找另外一種方法了。


#include<ntddk.h>


//EPROCESS結(jié)構(gòu)大小,我的系統(tǒng)是XP SP3,所以0x260,不過(guò)經(jīng)過(guò)測(cè)試,這里設(shè)置成比實(shí)際EPROCESS小也是沒(méi)問(wèn)題的
#define  EPROCESS_SIZE       0x260 
#define  PEB_OFFSET          0x1B0        //PEB偏移,下面就不注釋了
#define  FILE_NAME_OFFSET    0x174
#define  PROCESS_LINK_OFFSET 0x088
#define  PROCESS_ID_OFFSET   0x084
#define  EXIT_TIME_OFFSET    0x078

#define  OBJECT_HEADER_SIZE  0x018
#define  OBJECT_TYPE_OFFSET  0x008


ULONG        ulPebAddress;                        
//PEB地址的前半部分
ULONG        ulStartAddress, ulEndAddress;        //起始,結(jié)束地址
ULONG        ulObjectType;                        //進(jìn)程對(duì)象類型

BOOLEAN        IsaRealProcess(ULONG pEprocess);    
//該函數(shù)判斷是否真的是進(jìn)程
VOID        WorkThread(IN PVOID pContext);        //新開(kāi)線程防止系統(tǒng)頓卡
VOID        UpdateEndStartPebAddress();            //更新首尾地址和PEB地址
VOID        EnumProcess();                        //枚舉進(jìn)程
VOID        ShowProcess(ULONG pEProcess);        //顯示進(jìn)程信息

VOID OnUnload(IN PDRIVER_OBJECT DriverObject)
{
}

NTSTATUS DriverEntry(IN PDRIVER_OBJECT DriverObject,IN PUNICODE_STRING RegistryPath)
{
    HANDLE hThread;

    DriverObject 
-> DriverUnload = OnUnload;
    UpdateEndStartPebAddress();

    ulObjectType 
= *(PULONG)((ULONG)ulEndAddress - OBJECT_HEADER_SIZE + OBJECT_TYPE_OFFSET);
    PsCreateSystemThread(
&hThread,
        (ACCESS_MASK)
0,
        NULL, 
        (HANDLE)
0
        NULL, 
        WorkThread, 
        NULL ); 

    
return STATUS_SUCCESS;
}
//////////////////////////////////////////////
VOID WorkThread(IN PVOID pContext)

    EnumProcess();
    PsTerminateSystemThread(STATUS_SUCCESS);
}
////////////////////////////////////////////////////////
VOID UpdateEndStartPebAddress()
{
    ULONG ulEProcessAddress 
= (ULONG)IoGetCurrentProcess();
    ULONG pEProcess;
    
//IoGetCurrentProcess返回的是System進(jìn)程EPROCESS結(jié)構(gòu)地址,此處已經(jīng)是搜索結(jié)束處。
    ulStartAddress = ulEndAddress = ulEProcessAddress;

    ulEProcessAddress 
= (ULONG)(((PLIST_ENTRY)(ulEProcessAddress + PROCESS_LINK_OFFSET))->Flink) - PROCESS_LINK_OFFSET;
    ulPebAddress 
= *(PULONG)(ulEProcessAddress + PEB_OFFSET) & 0xFFFF0000;

    
while (ulEProcessAddress != ulEndAddress) 
    {        
//遍歷EPROCESS結(jié)構(gòu),找到最小地址處
        ulEProcessAddress = (ULONG)(((PLIST_ENTRY)(ulEProcessAddress + PROCESS_LINK_OFFSET))->Flink) - PROCESS_LINK_OFFSET;
        
if (ulStartAddress > ulEProcessAddress)
            ulStartAddress 
= ulEProcessAddress;
    }
}
///////////////////////////////////////////////////////
VOID EnumProcess()
{

    ULONG  i;
    ULONG nCount 
= 2;
    ULONG  Address;
    ULONG  ret;

    KdPrint((
"-------------------------------------------\r\n"));
    KdPrint((
"EProcess    PID    ImageFileName\r\n"));
    KdPrint((
"-------------------------------------------\r\n"));
    
//系統(tǒng)空閑進(jìn)程的檢測(cè)方法有點(diǎn)特殊,只作參考
    ShowProcess(*(PULONG)(ulStartAddress + PROCESS_ID_OFFSET));
    
//system的PEB總是零 上面的方法是枚舉不到的 不過(guò)我們用PsGetCurrentProcess就能得到了
    ShowProcess(ulEndAddress);

    
for(i = ulStartAddress; i < ulEndAddress; i += 4) {//system進(jìn)程的EPROCESS地址就是最大值了
        if (MmIsAddressValid((PVOID)i)) {
            Address 
= *(PULONG)i;
            
if (( Address & 0xFFFF0000== ulPebAddress){//每個(gè)進(jìn)程的PEB地址都是在差不多的地方,地址前半部分是相同的       
                if (IsaRealProcess(i)) {
                    ShowProcess(i 
- PEB_OFFSET);
                    i 
-= 4;
                    i 
+= EPROCESS_SIZE;
                    nCount 
++;
                }
            }
        } 
else {
            i 
-= 4;
            i 
+= 0x5000000;//5M
        }
    }    
    KdPrint((
"-------------------------------------------\r\n"));
    KdPrint((
"=====   Total Processes count:%3d   =======\r\n", nCount));
    KdPrint((
"-------------------------------------------\r\n"));
}
/////////////////////////////////////////////////////////
VOID ShowProcess(ULONG pEProcess)
{
    PLARGE_INTEGER ExitTime;
    ULONG PID;
    PUCHAR pFileName;

    ExitTime 
= (PLARGE_INTEGER)(pEProcess + EXIT_TIME_OFFSET);
    
if(ExitTime->QuadPart != 0//已經(jīng)結(jié)束的進(jìn)程的ExitTime為非零
        return ;

    PID 
= *(PULONG)(pEProcess + PROCESS_ID_OFFSET);
    pFileName 
= (PUCHAR)(pEProcess + FILE_NAME_OFFSET);

    KdPrint((
"0x%08X  %04d   %s\r\n",pEProcess,PID,pFileName));
}
////////////////////////////////////////////////////////////////
BOOLEAN IsaRealProcess(ULONG pEprocess)
{
    NTSTATUS STATUS;
    PUNICODE_STRING pUnicode;
    UNICODE_STRING Process;
    ULONG pObjectType;
    ULONG ObjectTypeAddress;

    
if (!MmIsAddressValid((PVOID)(pEprocess - PEB_OFFSET)))
        
return FALSE;

    ObjectTypeAddress 
= pEprocess - PEB_OFFSET - OBJECT_HEADER_SIZE + OBJECT_TYPE_OFFSET ;

    
if (MmIsAddressValid((PVOID)ObjectTypeAddress)) {
        pObjectType 
= *(PULONG)ObjectTypeAddress;
    } 
else {
        
return FALSE;
    }

    
if(ulObjectType == pObjectType) {//確定ObjectType是Process類型
        return TRUE;
    }
    
return FALSE;
}

Feedback

# re: ring0級(jí)暴力搜索內(nèi)存檢測(cè)系統(tǒng)隱藏進(jìn)程(或Rootkit)  回復(fù)  更多評(píng)論   

2012-10-04 19:04 by lam
感謝博主分享:D

# re: ring0級(jí)暴力搜索內(nèi)存檢測(cè)系統(tǒng)隱藏進(jìn)程(或Rootkit)  回復(fù)  更多評(píng)論   

2013-08-05 08:27 by carain
請(qǐng)問(wèn)我在windows2003 X64中修改了偏移值,但是會(huì)藍(lán)屏,還需要修改那些地方呢?郵箱:caran@foxmail.com 望回答

# re: ring0級(jí)暴力搜索內(nèi)存檢測(cè)系統(tǒng)隱藏進(jìn)程(或Rootkit)  回復(fù)  更多評(píng)論   

2015-02-04 15:18 by dumingqiao
同問(wèn)下 我在2003 32位下修改了偏移測(cè)試也藍(lán)呢 初學(xué)者不太懂 望指教下。
企鵝 905969973

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产日韩在线| 久久综合色8888| 狠狠做深爱婷婷久久综合一区 | 国产精品永久入口久久久| 久久综合九色综合欧美狠狠| 亚洲电影免费在线| 久久激情中文| 久久青草久久| 国精品一区二区| 国产日产欧美精品| 久久视频国产精品免费视频在线| 久久久久久久一区二区| 国产一区二区高清| 一区二区三区精品在线 | 女女同性女同一区二区三区91| 亚洲第一视频| 久久久久久婷| 欧美成人一区二区三区片免费| 欧美国产先锋| 久久九九国产精品| 欧美黄色精品| 国产三级欧美三级| 欧美精品尤物在线| 欧美在线关看| 一区二区三区在线视频播放| 久久精品av麻豆的观看方式| 久久国产免费看| 欧美一区二区三区视频在线| 在线成人亚洲| 国产精品午夜国产小视频| 国内精品视频一区| 亚洲国产精品女人久久久| 原创国产精品91| 久久精品亚洲一区二区| 欧美精品一卡| 国产日韩欧美一区二区| 亚洲精品国产精品国产自| 午夜久久福利| 亚洲国产日韩在线| 欧美伊人久久久久久久久影院 | 欧美成人日韩| 午夜久久黄色| 欧美aaaaaaaa牛牛影院| 亚洲国产精品一区二区尤物区| 亚洲国产精品精华液网站| 亚洲精品婷婷| 午夜精品理论片| 欧美一区午夜视频在线观看| 欧美日韩a区| 国产视频综合在线| 一本大道久久a久久综合婷婷| 欧美一区二区福利在线| 毛片精品免费在线观看| 亚洲国产精品ⅴa在线观看 | 久久青草久久| 在线亚洲欧美| 亚洲大胆av| 免费成人高清| 一本色道久久综合亚洲精品不| 国产精品视频yy9299一区| 亚洲一区二区网站| 久久亚洲春色中文字幕| 国产精品久久久久国产a级| 亚洲激情电影在线| 久久久精品动漫| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美mv日韩mv国产网站app| 欧美一级成年大片在线观看| 欧美不卡视频| 欧美一级片久久久久久久| 亚洲国产精品激情在线观看| 亚洲国产欧美国产综合一区| 亚洲第一区在线| 亚洲欧美日韩综合| 久久天天狠狠| 亚洲另类一区二区| 国产精品高清在线| 亚洲欧美一区二区三区久久| 久久久久久久综合色一本| 亚洲国产精品一区二区久| 国产精品成人一区二区网站软件| 国产欧美精品日韩精品| 亚洲国产日韩欧美在线动漫| 国产一区二区三区成人欧美日韩在线观看 | 久久人人爽人人爽| 亚洲免费视频成人| 欧美视频一区二区| 欧美第一黄色网| 欧美精品久久99| 一区二区三区欧美日韩| 99视频一区二区| 国产精品无码永久免费888| 久久久久se| 欧美成年视频| 免费观看久久久4p| 欧美精品在线播放| 午夜精彩国产免费不卡不顿大片| 午夜精品久久久久久久久久久久| 国产一区二区三区精品欧美日韩一区二区三区| 久久久久久久999| 久久综合色播五月| 一区二区免费在线视频| 亚洲综合日韩在线| 91久久国产综合久久91精品网站| 亚洲乱码国产乱码精品精天堂 | 先锋a资源在线看亚洲| 亚洲已满18点击进入久久| 国产色综合久久| 亚洲国产精品va在线观看黑人| 国产精品v日韩精品| 美脚丝袜一区二区三区在线观看 | 亚洲色诱最新| 亚洲第一网站| 亚洲免费视频中文字幕| 亚洲综合色激情五月| 狠狠久久亚洲欧美专区| 欧美韩国在线| 国产欧美一区二区三区沐欲| 麻豆国产va免费精品高清在线| 欧美伦理在线观看| 欧美一区精品| 欧美顶级少妇做爰| 亚洲欧美在线免费| 久久久久五月天| 亚洲系列中文字幕| 欧美一区二区三区免费视| 一区二区三区久久| 欧美暴力喷水在线| 久久久久国产精品厨房| 欧美亚洲成人精品| 99re6热只有精品免费观看| 亚洲电影在线| 亚洲欧美日韩另类| 午夜免费日韩视频| 欧美高清在线精品一区| 久久久噜噜噜久久久| 国产精品xxxxx| 99天天综合性| 99re热这里只有精品视频| 久久久女女女女999久久| 久久久www成人免费无遮挡大片| 国产精品成人免费| 一区二区三区久久| 99re6这里只有精品| 欧美日韩大陆在线| 日韩视频―中文字幕| 亚洲精品黄色| 欧美连裤袜在线视频| 99国产精品自拍| 99re6这里只有精品视频在线观看| 欧美精品少妇一区二区三区| 91久久精品一区二区三区| 国产在线观看精品一区二区三区 | 在线观看欧美| 久久精品国产77777蜜臀| 久久久精品国产免费观看同学| 欧美视频一区二区在线观看| 日韩视频免费看| 99精品国产热久久91蜜凸| 欧美大尺度在线| 亚洲国产精品v| 亚洲深夜福利视频| 欧美午夜精品久久久久久人妖| 亚洲免费观看在线观看| 国产精品久久看| 巨乳诱惑日韩免费av| 亚洲第一福利视频| 欧美插天视频在线播放| 亚洲啪啪91| 亚洲小说春色综合另类电影| 国产精品欧美一区二区三区奶水| 午夜精品美女久久久久av福利| 久久久久亚洲综合| 在线观看视频一区二区| 欧美不卡在线| 亚洲欧美在线磁力| 久久精品日韩欧美| 亚洲高清资源综合久久精品| 免费高清在线一区| 亚洲视频1区| 久色成人在线| 一个色综合av| 国产人久久人人人人爽| 久久综合九色综合欧美狠狠| 99国产精品| 欧美成人dvd在线视频| 中文av一区特黄| 亚洲国产导航| 国产精品夜夜夜| 欧美v日韩v国产v| 亚洲美女黄色| 欧美国产日韩一区二区三区| 欧美一区二区三区在| 亚洲精品乱码久久久久久日本蜜臀 | 亚洲欧洲一区二区三区在线观看 | 国产精品日本一区二区| 老司机午夜精品| 在线视频你懂得一区| 欧美国产另类| 久久久久久欧美|