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

最近期末答辯不知道寫什么好,就寫一個安全軟件吧。軟件使用驅動和C++編寫,大概多數安全軟件都是這樣吧。
時間關系,就不說那么多了,直接入正題吧。
在此先感謝“伊麗_殺_白”、“墮落天才”、“antirootkit”等提供的優秀文章,我只是在他們基礎之上修改了一下。

伊麗_殺_白    暴力搜索內存空間檢測隱藏進程:http://bbs.xdnice.com/thread-377796-1-1.html

墮落天才        ring0檢測隱藏進程:http://bbs.pediy.com/showthread.php?t=44243

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

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




下面看代碼吧,沒時間了,等下十點還要上課,有不明白的可以留言。我會解答的。
 
不過這種方法還是很容易躲過,詳細就不公布出來了,看來還是要找另外一種方法了。


#include<ntddk.h>


//EPROCESS結構大小,我的系統是XP SP3,所以0x260,不過經過測試,這里設置成比實際EPROCESS小也是沒問題的
#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;        //起始,結束地址
ULONG        ulObjectType;                        //進程對象類型

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

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進程EPROCESS結構地址,此處已經是搜索結束處。
    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結構,找到最小地址處
        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"));
    
//系統空閑進程的檢測方法有點特殊,只作參考
    ShowProcess(*(PULONG)(ulStartAddress + PROCESS_ID_OFFSET));
    
//system的PEB總是零 上面的方法是枚舉不到的 不過我們用PsGetCurrentProcess就能得到了
    ShowProcess(ulEndAddress);

    
for(i = ulStartAddress; i < ulEndAddress; i += 4) {//system進程的EPROCESS地址就是最大值了
        if (MmIsAddressValid((PVOID)i)) {
            Address 
= *(PULONG)i;
            
if (( Address & 0xFFFF0000== ulPebAddress){//每個進程的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//已經結束的進程的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級暴力搜索內存檢測系統隱藏進程(或Rootkit)  回復  更多評論   

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

# re: ring0級暴力搜索內存檢測系統隱藏進程(或Rootkit)  回復  更多評論   

2013-08-05 08:27 by carain
請問我在windows2003 X64中修改了偏移值,但是會藍屏,還需要修改那些地方呢?郵箱:caran@foxmail.com 望回答

# re: ring0級暴力搜索內存檢測系統隱藏進程(或Rootkit)  回復  更多評論   

2015-02-04 15:18 by dumingqiao
同問下 我在2003 32位下修改了偏移測試也藍呢 初學者不太懂 望指教下。
企鵝 905969973
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲性线免费观看视频成熟| 亚洲黄色尤物视频| 亚洲精品视频免费| 久久久久国色av免费看影院| 欧美中文在线观看| 依依成人综合视频| 欧美日韩国内| 久久本道综合色狠狠五月| 亚洲第一在线综合在线| 亚洲日本va在线观看| 欧美精品久久久久久久久老牛影院| 一本色道婷婷久久欧美| 久久久欧美一区二区| 韩国在线一区| 亚洲激情电影在线| 欧美一区二区福利在线| 亚洲欧美日韩视频一区| 99re66热这里只有精品3直播 | 欧美va天堂在线| 亚洲国产婷婷综合在线精品| 亚洲欧美日韩综合国产aⅴ| 国内外成人免费视频 | 亚洲视频一区二区在线观看| 久久久国产精品一区| 久久精品亚洲精品国产欧美kt∨| 久久精品一二三区| 亚洲黄网站黄| 欧美激情视频一区二区三区免费| 欧美国产激情二区三区| 欧美色中文字幕| 国产一区二区三区四区在线观看| 国产一区在线观看视频| 永久555www成人免费| 99视频一区二区| 欧美在线亚洲| 亚洲国产成人av| 亚洲视频在线二区| 久久精品亚洲精品国产欧美kt∨| 欧美国产一区二区在线观看| 国产偷国产偷亚洲高清97cao| 亚洲国产精品成人久久综合一区| 亚洲视频每日更新| 欧美gay视频| 亚洲欧美国产77777| 欧美国产综合视频| 激情成人综合网| 亚洲欧美中文日韩在线| 亚洲精品少妇30p| 免费观看日韩av| 国产一区清纯| 午夜精品久久久久久久久久久久| 亚洲国产精品久久久久秋霞影院 | 欧美ab在线视频| 亚洲欧美精品中文字幕在线| 欧美激情亚洲另类| 在线成人黄色| 欧美日韩国产精品专区| 在线看国产日韩| 久久偷看各类wc女厕嘘嘘偷窃| 中文国产一区| 亚洲视频图片小说| 欧美精品九九| 99人久久精品视频最新地址| 欧美国产91| 美女脱光内衣内裤视频久久影院| 一区二区三区自拍| 久久国产视频网站| 国产精品99久久久久久久vr| 亚洲无人区一区| 国产精品久久久久久妇女6080 | 在线观看三级视频欧美| 中文av字幕一区| 亚洲黄色尤物视频| 欧美日韩1080p| 久久久久久久久久久久久久一区| 国产日韩av高清| 久久精品五月婷婷| 久久本道综合色狠狠五月| 狠狠操狠狠色综合网| 国产视频一区二区三区在线观看| 国产视频精品xxxx| 久久精品国产精品亚洲| 久久久久久国产精品mv| 在线观看欧美日本| 欧美电影专区| 欧美激情综合| 亚洲综合激情| 欧美专区亚洲专区| 亚洲国产精品日韩| 一区二区不卡在线视频 午夜欧美不卡'| 影视先锋久久| 久久性色av| 欧美精品导航| 国产精品午夜av在线| 一区二区欧美在线| 亚洲综合丁香| 亚洲欧洲精品天堂一级| 亚洲午夜小视频| 亚洲电影免费观看高清| 一本大道久久精品懂色aⅴ| 国产一区二区三区电影在线观看| 最新亚洲视频| 夜夜嗨av一区二区三区网页| 国产精品主播| 欧美激情五月| 国产欧美精品一区二区色综合| 欧美sm极限捆绑bd| 欧美天堂亚洲电影院在线观看 | 欧美成人69av| 国产精品黄页免费高清在线观看| 久久久亚洲成人| 欧美色精品在线视频| 久热精品视频| 国产偷久久久精品专区| 亚洲乱码视频| 影音先锋亚洲精品| 一区二区三区蜜桃网| 亚洲第一精品福利| 正在播放亚洲| 亚洲人成77777在线观看网| 久久人人97超碰国产公开结果 | 欧美日本一道本| 久久天堂成人| 国产精品一区二区在线| av不卡在线| 亚洲国产综合在线看不卡| 香蕉av福利精品导航| 亚洲一区二区三区精品动漫| 欧美一区二区三区播放老司机 | 欧美+亚洲+精品+三区| 欧美在线一级视频| 欧美性开放视频| 日韩午夜中文字幕| 亚洲激情综合| 久久久噜噜噜久久| 136国产福利精品导航网址应用| 亚洲午夜未删减在线观看| 久久久久久久久久久久久久一区| 亚洲免费视频成人| 欧美女主播在线| 美女视频一区免费观看| 国产日韩精品一区二区浪潮av| 艳妇臀荡乳欲伦亚洲一区| 一本色道久久综合狠狠躁的推荐| 久久一区精品| 亚洲一区二区成人在线观看| 欧美日韩一区二区三区在线观看免| 欧美成人免费一级人片100| 国产一区二区精品丝袜| 午夜欧美精品久久久久久久| 欧美在线观看网站| 国产精品一区二区欧美| 久久久久久夜| 国产自产女人91一区在线观看| 亚洲视频1区2区| 欧美日韩在线高清| 一区二区三区视频免费在线观看| 亚洲影视九九影院在线观看| 欧美日韩一区二区欧美激情 | 欧美性jizz18性欧美| 9人人澡人人爽人人精品| 99re热这里只有精品免费视频| 欧美aa国产视频| 亚洲日本无吗高清不卡| 亚洲视频在线一区| 国产精品a久久久久久| 亚洲欧美日韩电影| 午夜精品久久久久久| 国产一区日韩一区| 欧美护士18xxxxhd| 亚洲综合三区| 欧美成人影音| 午夜影院日韩| 亚洲激情婷婷| 国产农村妇女精品一二区| 久久青草欧美一区二区三区| 亚洲国产色一区| 先锋a资源在线看亚洲| 亚洲国产成人tv| 国产精品久久久久国产a级| 久久中文在线| 亚洲一区二区在线播放| 男女激情久久| 亚洲午夜在线观看视频在线| 狠狠色伊人亚洲综合网站色| 欧美日韩精品在线播放| 欧美亚洲综合久久| 亚洲国产天堂久久综合网| 在线 亚洲欧美在线综合一区| 女人色偷偷aa久久天堂| 久久综合久色欧美综合狠狠| 一区二区三区精密机械公司 | 欧美日韩中字| 一本色道88久久加勒比精品 | 亚洲一二三级电影| 国产日韩精品电影| 一区二区欧美国产| 中日韩美女免费视频网址在线观看| 一区二区三区我不卡| 玖玖国产精品视频|