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

posts - 101,  comments - 57,  trackbacks - 0

內核態實現進程和端口關聯
 
//////////////////////////////////////////////////////////////////////////////////////////
//  作者 beiyu http://beiyu.bokee.com
//  內核態實現進程和端口關聯,在WINDOWS2000.xp,2003下可以用。
//  感謝Leven公布了他的代碼,增加了區分tcp,udp,增加了操作系統的兼容性
//  可以在Windows 2000, xp, 2003下面正常使用,編譯環境Win2000DDK
//  使用妳的sys loader加載,使用Dbgview查看
//  如果你有什么改進,請email我: beiyuly@gmail.com 
//
//////////////////////////////////////////////////////////////////////////////////////////
#include <ntddk.h>
#include <string.h>

#define SystemHandleInformation  16
#define TCPUDP_FLAG   100
#define WIN2K_SOCKET_FLAG  0x1a //2k
#define WINXP_SOCKET_FLAG  0x1c //xp
#define WIN2K3_SOCKET_FLAG  0x1a //2k3
#define WIN2K_EPROCESS_NAMEOFFSET    0x1fc //2k
#define WINXP_EPROCESS_NAMEOFFSET    0x174 //xp
#define WIN2K3_EPROCESS_NAMEOFFSET   0x1fc //2k3

#define ObjectNameInformation  1
#define ObjectAllTypesInformation 3

/*
typedef struct _OBJECT_NAME_INFORMATION {
UNICODE_STRING Name;
} OBJECT_NAME_INFORMATION, *POBJECT_NAME_INFORMATION;

typedef struct _OBJECT_TYPE_INFORMATION {
UNICODE_STRING Name;
ULONG ObjectCount;
ULONG HandleCount;
ULONG Reserved1[4];
ULONG PeakObjectCount;
ULONG PeakHandleCount;
ULONG Reserved2[4];
ULONG InvalidAttributes;
GENERIC_MAPPING GenericMapping;
ULONG ValidAccess;
UCHAR Unknown;
BOOLEAN MaintainHandleDatabase;
POOL_TYPE PoolType;
ULONG PagedPoolUsage;
ULONG NonPagedPoolUsage;
} OBJECT_TYPE_INFORMATION, *POBJECT_TYPE_INFORMATION;

typedef struct _OBJECT_ALL_TYPES_INFORMATION {
ULONG NumberOfTypes;
OBJECT_TYPE_INFORMATION TypeInformation;
} OBJECT_ALL_TYPES_INFORMATION, *POBJECT_ALL_TYPES_INFORMATION;
*/

#define ntohs(s) \
    ( ( ((s) >> 8) & 0x00FF ) | \
( ((s) << 8) & 0xFF00 ) )

typedef struct _TDI_CONNECTION_INFO {
    ULONG          State;
    ULONG          Event;
    ULONG          TransmittedTsdus;
    ULONG          ReceivedTsdus;
    ULONG          TransmissionErrors;
    ULONG          ReceiveErrors;
    LARGE_INTEGER  Throughput;
    LARGE_INTEGER  Delay;
    ULONG          SendBufferSize;
    ULONG          ReceiveBufferSize;
    BOOLEAN        Unreliable;
} TDI_CONNECTION_INFO, *PTDI_CONNECTION_INFO;

typedef struct _TDI_CONNECTION_INFORMATION {
    LONG   UserDataLength;
    PVOID  UserData;
    LONG   OptionsLength;
    PVOID  Options;
    LONG   RemoteAddressLength;
    PVOID  RemoteAddress;
} TDI_CONNECTION_INFORMATION, *PTDI_CONNECTION_INFORMATION;

typedef struct _SYSTEM_HANDLE_INFORMATION
{
        ULONG ProcessID;        //進程的標識ID
        UCHAR ObjectTypeNumber;        //對象類型
        UCHAR Flags;             //0x01 = PROTECT_FROM_CLOSE,0x02 = INHERIT
        USHORT Handle;             //對象句柄的數值
        PVOID  Object;            //對象句柄所指的內核對象地址 WinNT4/Windows2000是0x1A xp中是0x1c 2003中是
        ACCESS_MASK GrantedAccess;      //創建句柄時所準許的對象的訪問權
}SYSTEM_HANDLE_INFORMATION, * PSYSTEM_HANDLE_INFORMATION;

NTSYSAPI
NTSTATUS
NTAPI
ZwQuerySystemInformation(
    IN ULONG SystemInformationClass,
    IN OUT PVOID SystemInformation,
    IN ULONG SystemInformationLength,
    OUT PULONG ReturnLength);

NTSYSAPI
NTSTATUS
NTAPI
NtDeviceIoControlFile(
                      IN HANDLE FileHandle,
                      IN HANDLE Event OPTIONAL,
                      IN PIO_APC_ROUTINE ApcRoutine OPTIONAL,
                      IN PVOID ApcContext OPTIONAL,
                      OUT PIO_STATUS_BLOCK IoStatusBlock,
                      IN ULONG IoControlCode,
                      IN PVOID InputBuffer OPTIONAL,
                      IN ULONG InputBufferLength,
                      OUT PVOID OutputBuffer OPTIONAL,
                      IN ULONG OutputBufferLength
                      );

NTSYSAPI
NTSTATUS
NTAPI
ZwQueryObject(
     IN HANDLE ObjectHandle,
     IN ULONG ObjectInformationClass,
     OUT PVOID ObjectInformation,
     IN ULONG ObjectInformationLength,
     OUT PULONG ReturnLength OPTIONAL
     );

NTSYSAPI
BOOLEAN
NTAPI
NtDuplicateObject(
  IN HANDLE hSourceProcessHandle,
  IN HANDLE hSourceHandle,
  IN HANDLE hTargetProcessHandle,
  OUT HANDLE * lpTargetHandle,
  IN ULONG dwDesiredAccess,
  IN BOOLEAN bInheritHandle,
  IN ULONG dwOptions
);

NTSYSAPI
NTSTATUS
NTAPI
PsLookupProcessByProcessId(
     IN ULONG ulProcId,
     OUT PEPROCESS * pEProcess
     );


NTSTATUS
DriverEntry(IN PDRIVER_OBJECT DriverObject,
            IN PUNICODE_STRING RegistryPath);

void DriverUnload(IN PDRIVER_OBJECT DriverObject);

//幾個全局變量,記錄端口相關信息,最后列印出來
ULONG g_pid[1000];
ULONG g_port[1000];
ULONG g_handle[1000];
ULONG g_tcpudp[1000];
ULONG g_num =0 ;
ULONG g_tu[1000]; //g_tu=0 tcp, g_tu=1 udp

//獲得所有句柄
ULONG GetHandleList()
{
    ULONG n;
    ULONG pBuffer;
    NTSTATUS status;
DbgPrint("GetHandleList\n");

    pBuffer =(ULONG)ExAllocatePool(PagedPool,0x1000);
    status = ZwQuerySystemInformation(SystemHandleInformation,(PVOID)pBuffer,0x1000,&n);
    ExFreePool((PVOID)pBuffer);
    if(STATUS_INFO_LENGTH_MISMATCH == status)
    {
        pBuffer =(ULONG)ExAllocatePool(NonPagedPool,n);
        ZwQuerySystemInformation(SystemHandleInformation,(PVOID)pBuffer,n,NULL);
        return pBuffer;
    }
    else
        return 0;
}

//根據句柄得到端口信息
void GetOpenPort(ULONG dwProcessesID,ULONG Handle,int NoCache,ULONG tcpudp)
{
    HANDLE hProc,DupHandle=NULL;
    USHORT openport;
    ULONG i=0;
    NTSTATUS status;
    TDI_CONNECTION_INFO    TdiConnInfo={0};
    TDI_CONNECTION_INFORMATION TdiConnInformation={0};
    ULONG dwRetu=0;   
    IO_STATUS_BLOCK    IoStatusBlock={0};
    CLIENT_ID id;
    OBJECT_ATTRIBUTES objatt = {0};
POBJECT_NAME_INFORMATION ObjectName;
char ObjectNameBuf[512];
// char ObjectNameMBS[261];
ULONG ReturnLen;
ObjectName = (POBJECT_NAME_INFORMATION)ObjectNameBuf;
ObjectName->Name.MaximumLength = 500;

    //DbgPrint("GetOpenPort\n");

    id.UniqueProcess = (HANDLE)dwProcessesID;
    id.UniqueThread = 0;
//打開對方進程
    NtOpenProcess(&hProc,PROCESS_DUP_HANDLE,&objatt,&id);
//復制句柄
    NtDuplicateObject(hProc,
        (HANDLE)Handle,
        (HANDLE)0xffffffff,
        &DupHandle,
        0,
        FALSE,
        2);
//根據object的數據得到端口信息
    if(NoCache==0x2)
    {
  //取得句柄關聯的對象的信息
  ZwQueryObject(DupHandle, ObjectNameInformation, ObjectName, sizeof(ObjectNameBuf), &ReturnLen);

        TdiConnInformation.RemoteAddressLength= 4;
        status = NtDeviceIoControlFile((HANDLE)DupHandle,  
              NULL,
        NULL,
        NULL,
        &IoStatusBlock,
        0x210012,  // Command code
        &TdiConnInformation,
        sizeof(TdiConnInformation),
        &TdiConnInfo,
        sizeof(TdiConnInfo));

        //進行TDI查詢,得到連接的相關信息
        if(status == 0)
        {
            openport = ntohs((USHORT)TdiConnInfo.ReceivedTsdus);

            if(openport == 0)
                return;

            for(i=0;i            {
                if(g_pid == dwProcessesID && g_port == openport)
                    if(tcpudp >= TCPUDP_FLAG && g_tcpudp >= TCPUDP_FLAG || tcpudp < TCPUDP_FLAG && g_tcpudp < TCPUDP_FLAG)
                    return;
            }

            g_pid = dwProcessesID;
            g_port = openport;
            g_handle = Handle;
            g_tcpudp = tcpudp;
            g_num++;
   if (wcscmp(ObjectName->Name.Buffer, L"\\Device\\Tcp") == 0)
   {
    g_tu = 0;
   }
   if (wcscmp(ObjectName->Name.Buffer, L"\\Device\\Udp") == 0)
   {
    g_tu = 1;
   }
       }
    }
    if(NoCache==0x1)
    {
     ZwQueryObject(DupHandle, ObjectNameInformation, ObjectName, sizeof(ObjectNameBuf), &ReturnLen);

  TdiConnInformation.RemoteAddressLength= 3;
        status = NtDeviceIoControlFile((HANDLE)DupHandle,       
        NULL,
        NULL,
        NULL,
        &IoStatusBlock,
        0x210012,  // Command code
        &TdiConnInformation,
        sizeof(TdiConnInformation),
        &TdiConnInfo,
        sizeof(TdiConnInfo));                    
        //進行TDI查詢,得到連接的相關信息
         if(status == 0)
        {
            openport = ntohs((USHORT)TdiConnInfo.ReceivedTsdus);

            if(openport == 0)
                return;

            for(i=0;i            {
                if(g_pid == dwProcessesID && g_port == openport)
                    if(tcpudp >= TCPUDP_FLAG && g_tcpudp >= TCPUDP_FLAG || tcpudp < TCPUDP_FLAG && g_tcpudp < TCPUDP_FLAG)
                    return;
            }

            g_pid = dwProcessesID;
            g_port = openport;
            g_handle = Handle;
            g_tcpudp = tcpudp;
            g_num++;
   if (wcscmp(ObjectName->Name.Buffer, L"\\Device\\Tcp") == 0)
   {
    g_tu = 0;
   }
   if (wcscmp(ObjectName->Name.Buffer, L"\\Device\\Udp") == 0)
   {
    g_tu = 1;
   }
       }
    }
}

void Start(ULONG pBuffer)
{
    ULONG i;
//頭4個字節是所有的句柄的數目UNONG 32位
//從第5個字節開始就是結構體了
    PSYSTEM_HANDLE_INFORMATION pProcesses = (PSYSTEM_HANDLE_INFORMATION)(pBuffer+4);
    ULONG nocache;
    ULONG tcpudp;
    PEPROCESS epro;
    char *p;
    ULONG uMajorVersion;
    ULONG uMinorVersion;
    ULONG uBuildNumber;
    ULONG uOsVer;

    DbgPrint("Start11\n");


PsGetVersion(&uMajorVersion, &uMinorVersion, &uBuildNumber, NULL);
if(uMajorVersion == 5)
{
  if(uMinorVersion == 0)
  {
   DbgPrint("2k\n");
   uOsVer = 0;//2k
  }
  else if(uMinorVersion == 1)
  {
   uOsVer = 1;//xp
   DbgPrint("xp\n");
  }
  else if(uMinorVersion == 2)
  {
   uOsVer = 2;//2k3
   DbgPrint("2k3\n");
  }
  else
  {
   uOsVer = 3;//nt
   DbgPrint("NT\n");
  }
}
else
{
  uOsVer = 99;
  DbgPrint("Unknow OS\n");
}

    for (i=0;i<((ULONG)(*(ULONG*)pBuffer));i++)
    {
  //2000 xp 2003 三種操作系統
        if(pProcesses.ObjectTypeNumber == WIN2K_SOCKET_FLAG
   || pProcesses.ObjectTypeNumber == WINXP_SOCKET_FLAG
   || pProcesses.ObjectTypeNumber == WIN2K3_SOCKET_FLAG)
       {           
//得到SYSTEM_HANDLE_INFORMATION.object的相關數據
//這里要密切注意內存情況,一不小心就藍屏。因為句柄經常變化,有些可能已經被銷毀了
            nocache = (ULONG)pProcesses.Object;
            if(!MmIsAddressValid((VOID*)nocache))
                continue;
            nocache = (ULONG)(*((ULONG*)(nocache)+4));

            tcpudp = (ULONG)(*((ULONG*)(pProcesses.Object)+1));
            if(!MmIsAddressValid((VOID*)tcpudp))
                continue;
            tcpudp = (ULONG)(*((ULONG*)(tcpudp)+1));

            if(nocache == 2 || nocache == 1)
            {
                GetOpenPort(pProcesses.ProcessID,pProcesses.Handle,nocache,tcpudp);
            }
        }
    }

    for(i=0;i    {
//根據PID得到進程名
        PsLookupProcessByProcessId(g_pid,&epro);

  if(uOsVer == 0)
  { //2k中進程名在EPROCESS結構中的位置
   p = (char*)epro + WIN2K_EPROCESS_NAMEOFFSET;
   //DbgPrint("2k\n");
  }
  if(uOsVer == 1)
  { //xp中進程名在EPROCESS結構中的位置
   p = (char*)epro + WINXP_EPROCESS_NAMEOFFSET;
   //DbgPrint("xp\n");
  }
  if(uOsVer == 2)
  { //2k3中進程名在EPROCESS結構中的位置
   p = (char*)epro + WIN2K3_EPROCESS_NAMEOFFSET;
   //DbgPrint("2k3\n");
  }
  if(uOsVer == 3)
  {
   p = (char*)epro + WIN2K_EPROCESS_NAMEOFFSET; //NT
   //DbgPrint("nt\n");
  }

  if(uOsVer == 99)
  {
   //DbgPrint("Unknow OS\n");
   break;
  }

   if(g_tu == 0)
   DbgPrint("TCP:\tProcName=%s\tPID=%d\tport=%d\t%d\n",p,g_pid,g_port,g_tcpudp);
        if(g_tu == 1)
     DbgPrint("UDP:\tProcName=%s\tPID=%d\tport=%d\t%d\n",p,g_pid,g_port,g_tcpudp);
    
    }

    return;
}
//////////////////////////////////

NTSTATUS
DriverEntry(IN PDRIVER_OBJECT DriverObject,
            IN PUNICODE_STRING RegistryPath)
{
    ULONG pbuf;

    DbgPrint("DriverEntry\n");
   
    DriverObject->DriverUnload = DriverUnload;
   
    pbuf = GetHandleList();
    Start(pbuf);
   
    return STATUS_SUCCESS;
}


void DriverUnload(IN PDRIVER_OBJECT pDriverObject)
{
    NTSTATUS            status;
    //ResumeDestFunction();
    if(pDriverObject->DeviceObject != NULL)
{
  IoDeleteDevice( pDriverObject->DeviceObject );
}

DbgPrint("DriverUnload\n");
}

參考文獻:
1 Windows DDK
2 http://coffeeqiqi.blogchina.com
3 Leven-端口關聯進程-在核心態的實現方法
4 Msdn
5 port/connection hiding   http://dev.csdn.net/Develop/article/28/84294.shtm
6 在NT系列操作系統里讓自己“消失”
7 http://www.rootkit.com

posted on 2007-08-24 09:23 margin 閱讀(436) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2009年7月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

常用鏈接

留言簿

隨筆檔案

文章分類

文章檔案

收藏夾

常去的壇子

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

我的朋友

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

搜索

  •  

最新評論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产欧美一区二区精品秋霞影院| 欧美一级日韩一级| 亚洲国产成人在线视频| 亚洲综合另类| 米奇777在线欧美播放| 亚洲一区一卡| 最新中文字幕一区二区三区| 一区二区三区四区五区在线| 久久天天狠狠| 精品999久久久| 久久亚洲一区| 久久久久一区二区三区四区| 国产在线播放一区二区三区| 欧美在线综合| 久久成人精品无人区| 国产日韩欧美麻豆| 久久精品国产成人| 亚洲欧美电影在线观看| 欧美先锋影音| 亚洲欧美第一页| 亚洲欧美日韩精品久久| 国产欧美精品xxxx另类| 久久精品视频99| 久久精品91久久香蕉加勒比| 在线播放豆国产99亚洲| 国产精品一香蕉国产线看观看| 好看的av在线不卡观看| 久久久久久色| 久久一区二区三区国产精品| 在线观看精品一区| 亚洲级视频在线观看免费1级| 欧美高清你懂得| 亚洲私人影院| 亚洲男人av电影| 伊人婷婷久久| 亚洲激情在线观看| 国产精品啊啊啊| 久久精品日韩欧美| 麻豆国产精品777777在线| 99re66热这里只有精品3直播| 99视频精品全部免费在线| 久久久国产亚洲精品| 韩国成人福利片在线播放| 欧美激情一区二区三区不卡| 欧美精品18| 久久精品国产99国产精品澳门| 久久夜精品va视频免费观看| 在线亚洲精品| 久久精品国产精品亚洲综合| 亚洲国产精品久久久久秋霞不卡 | 欧美**人妖| 欧美国产日本在线| 欧美一区二区三区在线| 蜜桃精品久久久久久久免费影院| 亚洲午夜一二三区视频| 久久久久www| 亚洲女人小视频在线观看| 久久久综合网| 欧美在线在线| 欧美午夜精品久久久久久久 | 免费欧美高清视频| 小黄鸭精品aⅴ导航网站入口| 久热爱精品视频线路一| 性欧美大战久久久久久久久| 久久九九热免费视频| 亚洲一区二区三区在线看| 久久五月天婷婷| 亚洲综合另类| 欧美视频福利| 亚洲精品国产视频| 精品成人a区在线观看| 亚洲视屏在线播放| 一区二区三区四区五区视频 | 这里只有精品视频| 久久亚洲色图| 另类av一区二区| 欧美国产日本高清在线| 久热精品视频在线观看| 国产精品视频久久| 野花国产精品入口| 日韩视频一区二区三区在线播放免费观看 | 亚洲国产精品一区二区久 | 欧美日韩在线观看一区二区三区| 久久久噜噜噜久久| 国产精品美女主播在线观看纯欲| 亚洲高清一二三区| 亚洲国产福利在线| 久久精品亚洲| 久久资源在线| 激情综合网址| 久久久精品一品道一区| 久久天天躁狠狠躁夜夜av| 国产午夜精品全部视频播放| 亚洲欧美美女| 久久久噜噜噜久噜久久| 国产亚洲欧洲| 久久国产日本精品| 欧美成人高清视频| 亚洲精品一区二区三区在线观看| 欧美成人一区二免费视频软件| 亚洲成人资源| 亚洲免费观看在线观看| 欧美另类视频在线| 99精品99久久久久久宅男| 亚洲永久精品大片| 国产欧美日韩一级| 久久久亚洲高清| 亚洲欧洲一区二区在线播放| 亚洲特黄一级片| 国产精品亚洲片夜色在线| 久久综合五月| 日韩亚洲欧美成人| 国产精品啊啊啊| 欧美一区二区免费| 欧美国产精品中文字幕| 一区二区日韩| 国产人妖伪娘一区91| 美国十次成人| 亚洲午夜高清视频| 美女性感视频久久久| 夜久久久久久| 国产一区二区三区在线观看免费| 裸体素人女欧美日韩| 一本色道久久综合亚洲精品按摩| 欧美一区二区三区的| 亚洲国产综合视频在线观看| 欧美日韩在线第一页| 久久精品人人爽| 99国产一区| 你懂的亚洲视频| 亚洲欧美日韩区| 亚洲国产精品女人久久久| 欧美日韩亚洲一区二区三区在线观看| 亚洲一区精品视频| 欧美国产亚洲精品久久久8v| 亚洲在线黄色| 91久久精品国产91久久性色| 国产精品毛片va一区二区三区 | 亚洲九九精品| 久久久另类综合| 亚洲综合电影一区二区三区| 1000部国产精品成人观看| 国产精品a久久久久| 久久一区国产| 久久天天躁夜夜躁狠狠躁2022| 国产美女高潮久久白浆| 蜜臀99久久精品久久久久久软件| 国产精品大片| 欧美亚洲在线视频| 91久久精品一区| 国产亚洲一本大道中文在线| 欧美电影免费观看高清| 欧美在线一区二区| 亚洲一级在线| 亚洲精品免费观看| 欧美a级片网站| 久久裸体视频| 欧美在线不卡| 亚洲欧美日韩综合aⅴ视频| 亚洲精品久久久久中文字幕欢迎你| 国产欧美日韩不卡免费| 欧美日韩一区视频| 欧美激情在线观看| 狂野欧美一区| 久久久av网站| 久久www免费人成看片高清| 亚洲综合色自拍一区| 亚洲视频一区二区| 一区二区三欧美| av成人免费观看| 日韩午夜在线观看视频| 亚洲精品一区二区三区四区高清| 欧美成人免费在线| 欧美阿v一级看视频| 女人香蕉久久**毛片精品| 久久三级福利| 久久香蕉精品| 欧美.日韩.国产.一区.二区| 麻豆精品一区二区综合av| 久久人91精品久久久久久不卡| 久久国产精品99精品国产| 久久gogo国模裸体人体| 亚洲欧美综合另类中字| 西西人体一区二区| 欧美一区二区三区在线播放| 欧美一区激情| 浪潮色综合久久天堂| 欧美国产日韩亚洲一区| 亚洲国产一区二区三区高清| 亚洲三级性片| 亚洲一级免费视频| 欧美中文字幕在线视频| 久久在线免费观看视频| 欧美成人免费全部观看天天性色| 久久这里只精品最新地址| 男人天堂欧美日韩| 欧美日韩精品一二三区| 国产精品日韩精品| 狠狠做深爱婷婷久久综合一区| 亚洲高清免费在线|