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

牽著老婆滿街逛

嚴(yán)以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

ring0檢測隱藏進(jìn)程

 題: 【原創(chuàng)】ring0檢測隱藏進(jìn)程
作 者: 墮落天才
時(shí) 間: 2007-05-10,13:28
鏈 接: http://bbs.pediy.com/showthread.php?t=44243


//網(wǎng)上得到一篇好文章 Ring0下搜索內(nèi)存枚舉隱藏進(jìn)程 ,但是拿里面的代碼來使用的時(shí)候發(fā)現(xiàn)并沒有太多效果
//于是修改之,終于實(shí)現(xiàn)了最初的目標(biāo)
//由于直接搜索內(nèi)存,跟系統(tǒng)調(diào)度沒什么關(guān)系,所以能夠枚舉到各種方法隱藏的進(jìn)程 包括斷鏈、抹PspCidTable... 
//甚至能枚舉到已經(jīng)"死掉"的進(jìn)程,本程序通過進(jìn)程的ExitTime來判斷進(jìn)程是不是已經(jīng)結(jié)束
//除非能夠把EProcess結(jié)構(gòu)修改掉,但這個(gè)實(shí)現(xiàn)難度可能比較大,不知有沒有哪位大俠試過(PID我修改過),歡迎討論
//
//作者:墮落天才
//時(shí)間:2007年5月10日
//參考: uty  Ring0下搜索內(nèi)存枚舉隱藏進(jìn)程 http://www.cnxhacker.net/Article/show/3412.html
//下面代碼在XP SP2測試通過
#include<ntddk.h>

///////////////////////////不同的windows版本下面的偏移值不同
#define  EPROCESS_SIZE       0x25C //EPROCESS結(jié)構(gòu)大小

#define  PEB_OFFSET          0x1B0
#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

#define PDE_INVALID 2 
#define PTE_INVALID 1 
#define VALID 0 


ULONG     pebAddress;         
//PEB地址的前半部分
PEPROCESS pSystem;            //system進(jìn)程
ULONG     pObjectTypeProcess; //進(jìn)程對(duì)象類型

ULONG   VALIDpage(ULONG addr) ;  
//該函數(shù)直接復(fù)制自 Ring0下搜索內(nèi)存枚舉隱藏進(jìn)程
BOOLEAN IsaRealProcess(ULONG i); //該函數(shù)復(fù)制自 Ring0下搜索內(nèi)存枚舉隱藏進(jìn)程
VOID    WorkThread(IN PVOID pContext);
ULONG   GetPebAddress();          
//得到PEB地址前半部分
VOID    EnumProcess();            //枚舉進(jìn)程
VOID    ShowProcess(ULONG pEProcess); //顯示結(jié)果

VOID    OnUnload(IN PDRIVER_OBJECT DriverObject)
{
}

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

  DriverObject 
-> DriverUnload = OnUnload;

  pSystem    
= PsGetCurrentProcess();
  pebAddress 
= GetPebAddress();
  pObjectTypeProcess 
= *(PULONG)((ULONG)pSystem - 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);  
}

////////////////////////////////////////////////////////
ULONG  GetPebAddress()
{
  ULONG Address;
  PEPROCESS pEProcess;

        
//由于system進(jìn)程的peb總是零 我們只有到其他進(jìn)程去找了
  pEProcess = (PEPROCESS)((ULONG)((PLIST_ENTRY)((ULONG)pSystem + PROCESS_LINK_OFFSET))->Flink - PROCESS_LINK_OFFSET);
  Address   
= *(PULONG)((ULONG)pEProcess + PEB_OFFSET);

  
return (Address & 0xFFFF0000);  
}

///////////////////////////////////////////////////////
VOID EnumProcess()
{
  ULONG  uSystemAddress 
= (ULONG)pSystem;
  ULONG  i;
  ULONG  Address;
  ULONG  ret;

  DbgPrint(
"-------------------------------------------");
  DbgPrint(
"EProcess    PID    ImageFileName");
  DbgPrint(
"---------------------------------");
  

  
for(i = 0x80000000; i < uSystemAddress; i += 4){//system進(jìn)程的EPROCESS地址就是最大值了
    ret = VALIDpage(i); 
    
if (ret == VALID)
      Address 
= *(PULONG)i;
      
if (( Address & 0xFFFF0000== pebAddress){//每個(gè)進(jìn)程的PEB地址都是在差不多的地方,地址前半部分是相同的       
        if(IsaRealProcess(i))
          ShowProcess(i 
- PEB_OFFSET);  
           i 
+= EPROCESS_SIZE;                
        }
 
      }
 
    }
else if(ret == PTE_INVALID)
      i 
-=4
      i 
+= 0x1000;//4k 
    }
else
      i
-=4
      i
+= 0x400000;//4mb 
    }
 
  }


  ShowProcess(uSystemAddress);
//system的PEB總是零 上面的方法是枚舉不到的 不過我們用PsGetCurrentProcess就能得到了
  DbgPrint("-------------------------------------------");
  
}

/////////////////////////////////////////////////////////
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);

  DbgPrint(
"0x%08X  %04d   %s",pEProcess,PID,pFileName);
}

/////////////////////////////////////////////////////////////
ULONG VALIDpage(ULONG addr) 

  ULONG pte; 
  ULONG pde; 
  
  pde 
= 0xc0300000 + (addr>>22)*4
  
if((*(PULONG)pde & 0x1!= 0)
    
//large page 
    if((*(PULONG)pde & 0x80!= 0)
      
return VALID; 
    }
 
    pte 
= 0xc0000000 + (addr>>12)*4
    
if((*(PULONG)pte & 0x1!= 0)
      
return VALID; 
    }
else
      
return PTE_INVALID; 
    }
 
  }
 
  
return PDE_INVALID; 
}
 
////////////////////////////////////////////////////////////////
BOOLEAN IsaRealProcess(ULONG i) 

  NTSTATUS STATUS; 
  PUNICODE_STRING pUnicode; 
  UNICODE_STRING Process; 
  ULONG pObjectType; 
  ULONG ObjectTypeAddress; 
  
  
if (VALIDpage(i- PEB_OFFSET) != VALID)
    
return FALSE; 
  }
 

  ObjectTypeAddress 
= i - PEB_OFFSET - OBJECT_HEADER_SIZE + OBJECT_TYPE_OFFSET ;
  
  
if (VALIDpage(ObjectTypeAddress) == VALID)
    pObjectType 
= *(PULONG)ObjectTypeAddress; 
  }
else
    
return FALSE; 
  }
 
  
  
if(pObjectTypeProcess == pObjectType)//確定ObjectType是Process類型
    return TRUE; 
  }
 
  
return FALSE; 

}
 

posted on 2011-01-31 11:37 楊粼波 閱讀(1171) 評(píng)論(0)  編輯 收藏 引用


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   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>
            欧美一区二区三区免费视| 久久蜜桃资源一区二区老牛| 亚洲国产精品久久久久秋霞不卡| 伊人蜜桃色噜噜激情综合| 国产精品系列在线播放| 国产精品午夜在线| 亚洲成人原创| 亚洲黄色在线视频| 亚洲激情另类| 亚洲欧美另类在线| 亚洲欧美一区二区三区极速播放 | 国产精品美女久久久久久免费| 欧美精品自拍| 欧美日韩不卡一区| 欧美性大战久久久久| 国产精品一区二区欧美| 国产欧美日韩另类视频免费观看| 国产偷自视频区视频一区二区| 国产一区日韩二区欧美三区| 激情综合色丁香一区二区| 一区精品在线| 一二三区精品| 亚洲一区精彩视频| 久久精品一区二区国产| 嫩草影视亚洲| 亚洲精品九九| 亚洲直播在线一区| 欧美在线视频a| 鲁大师成人一区二区三区| 欧美成人亚洲成人日韩成人| 欧美另类变人与禽xxxxx| 国产一区二区中文字幕免费看| 一区二区三区高清在线观看| 亚洲欧洲av一区二区| 亚洲国产精品va在线看黑人 | 黑人巨大精品欧美黑白配亚洲| 1024精品一区二区三区| 午夜精品区一区二区三| 亚洲人成77777在线观看网| 久久久www| 欧美极品aⅴ影院| 国产精品日韩| 亚洲视频免费在线观看| 久久成人精品无人区| 浪潮色综合久久天堂| 亚洲精品美女在线| 老牛国产精品一区的观看方式| 国产精品激情av在线播放| 国内外成人免费激情在线视频 | 久久精品123| 欧美大片一区二区三区| 亚洲无线一线二线三线区别av| 久久久亚洲高清| 欧美日韩日韩| 精品成人一区| 久久久精品一区| 性欧美video另类hd性玩具| 欧美激情1区2区3区| 国产日韩欧美成人| 欧美亚洲一区| 亚洲日本aⅴ片在线观看香蕉| 媚黑女一区二区| 136国产福利精品导航网址| 久久一区精品| 一区二区三区欧美激情| 久久网站热最新地址| 在线观看亚洲视频| 女人色偷偷aa久久天堂| 久久青草久久| 亚洲国产欧美一区二区三区久久| 你懂的一区二区| 老色鬼久久亚洲一区二区| 亚洲国产91色在线| 久久国产婷婷国产香蕉| 欧美伊人久久久久久久久影院| 国产在线观看一区| 麻豆成人在线| 免费视频一区| 国产在线国偷精品产拍免费yy| 久久精品一区二区三区中文字幕| 欧美在线视频导航| 在线国产精品一区| 亚洲电影免费在线| 久久网站免费| 亚洲精品国产无天堂网2021| 免费久久精品视频| 欧美一区二区三区在线看| 韩国在线一区| 亚洲第一天堂无码专区| 欧美日韩在线视频观看| 亚洲人久久久| 亚洲国产成人高清精品| 欧美日韩亚洲三区| 性高湖久久久久久久久| 久久av一区二区三区漫画| 亚洲第一天堂av| 亚洲三级免费电影| 国产精品一卡二| 老司机免费视频久久| 欧美福利视频| 亚洲欧美日韩国产一区| 久久av一区二区三区| 亚洲精品国精品久久99热一| 在线视频欧美日韩| 国产精品久久久久aaaa| 久久久久久伊人| 欧美一区国产在线| 亚洲欧洲在线免费| 亚洲特级毛片| 尤妮丝一区二区裸体视频| 亚洲日本va午夜在线电影| 国产模特精品视频久久久久| 欧美电影电视剧在线观看| 欧美色大人视频| 久久视频这里只有精品| 欧美日韩免费观看一区=区三区| 久久精品国产清高在天天线| 欧美jizzhd精品欧美巨大免费| 亚洲欧美精品在线观看| 久久只精品国产| 亚洲欧美高清| 欧美高清在线观看| 久久精精品视频| 欧美日韩三级| 乱人伦精品视频在线观看| 欧美色图天堂网| 欧美mv日韩mv国产网站app| 国产精品久久国产精品99gif | 亚洲第一区色| 国产日韩一区二区三区| 亚洲精品国产精品国自产在线| 国产亚洲一区在线| 欧美大片第1页| 国产日韩精品一区二区三区| 亚洲国产日韩在线| 狠狠狠色丁香婷婷综合久久五月| 亚洲精品国产精品国自产观看浪潮| 国产亚洲精品一区二555| 一本大道久久a久久精二百| 欧美视频一区二| 久色成人在线| 国产麻豆综合| 日韩午夜三级在线| 国产偷国产偷亚洲高清97cao| 亚洲毛片在线| 国产日韩欧美三级| 一区二区国产在线观看| 亚洲精品小视频| 久久人91精品久久久久久不卡| 午夜精品久久久久久久99水蜜桃 | 99国产麻豆精品| 亚洲黄色免费电影| 久久久久久黄| 久久精品av麻豆的观看方式| 欧美性事在线| 亚洲美女中文字幕| 亚洲精品一区二区三| 久久免费国产| 久久天堂av综合合色| 国产夜色精品一区二区av| 亚洲午夜电影网| 亚洲欧美综合| 国产精品老牛| 在线视频亚洲| 亚洲综合日韩在线| 欧美三级电影一区| 亚洲最新在线视频| 中文亚洲视频在线| 欧美日韩国产黄| 亚洲精品日韩精品| 99国产精品国产精品久久| 欧美在线视频免费观看| 欧美在线视频全部完| 国产欧美日韩综合一区在线观看| 亚洲一区三区在线观看| 亚洲人成网站999久久久综合| 久久综合五月| 欧美激情视频给我| 激情视频一区二区三区| 久久久久久久综合色一本| 久久夜精品va视频免费观看| 黄色精品一区二区| 老司机免费视频一区二区| 欧美高清视频一区二区三区在线观看| 精品成人一区二区| 女生裸体视频一区二区三区| 亚洲丰满在线| 日韩视频免费大全中文字幕| 久久手机精品视频| 欧美电影免费| 99re8这里有精品热视频免费| 欧美日韩理论| 亚洲一卡久久| 久久久久国产精品麻豆ai换脸| 黄色日韩网站| 欧美大尺度在线观看| 99riav国产精品| 欧美伊人久久久久久午夜久久久久 | 久久国产精品久久久久久电车| 亚洲一区在线观看免费观看电影高清|