• <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>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            這問題都老生常談了,大家對于技術動向的跟蹤并不緊密呀,呵呵……
            貼段我自己的代碼,是用來枚舉機器中所有的winsock對象及其相關進程的,供參考。稍做修改可滿足各種需要。

            #include "stdafx.h"
            #include <stdio.h>
            #include <windows.h>
            #pragma comment(lib, "ws2_32.lib")
            typedef struct _HandleInfo
            {
            USHORT wPid;
            USHORT wCreatorBackTraceIndex;
            BYTE?? objType;
            BYTE?? handleAttibs;
            USHORT handleOffset;
            DWORD? dwKeObject;
            ULONG? dwGrantedAccess;

            }HANDLEINFO, *PHANDLEINFO;


            int main(int argc, char* argv[])
            {
            WSADATA wd;
            unsigned int ret = WSAStartup(0x0202, &wd);

            typedef DWORD (WINAPI *PQuerySystemInformation)(DWORD, PBYTE, DWORD, PDWORD);

            PQuerySystemInformation pQuerySystemInformation = (PQuerySystemInformation)GetProcAddress(GetModuleHandle("ntdll.dll"), "ZwQuerySystemInformation");
            if(pQuerySystemInformation == NULL)
            {
            MessageBox(NULL, "Can't find NtQuerySystemInformation int Ntdll.dll!", "Failed", 0);
            return 1;
            }

            BYTE *buf = new BYTE[20];
            PHANDLEINFO phandleinfo = NULL;
            DWORD dwRetSize = 0;
            DWORD dwNum = 0;
            unsigned int i;

            ret = pQuerySystemInformation(16, buf,20,&dwRetSize);
            if(0 != ret)
            {
            if(dwRetSize > 0)
            {
            //dwNum = dwRetSize/sizeof(HANDLEINFO);
            delete [] buf;
            buf = new BYTE[dwRetSize];
            ret = pQuerySystemInformation(16, buf, dwRetSize, &dwRetSize);
            if(0 != ret)
            {
            printf("Can't get any handles!\n");
            goto end;
            }
            }
            else
            {
            goto end;
            }
            }
            dwNum = *(DWORD*)buf;
            phandleinfo = (PHANDLEINFO)(buf+4);

            for(i=0;i<dwNum;i++)
            {
            //static int iCount = 0;
            //static WORD wPid = -1;
            HANDLEINFO *pSeek = phandleinfo + i;
            if((pSeek->objType==0x1a) && (pSeek->wPid))
            {
            //iCount++;
            //wPid = pSeek->wPid;

            HANDLE hSrcProcess;
            hSrcProcess = OpenProcess(PROCESS_ALL_ACCESS,TRUE, pSeek->wPid);
            if(hSrcProcess == NULL)
            continue;

            __try
            {

            SOCKET hSock;
            ret = DuplicateHandle(hSrcProcess, (HANDLE)(pSeek->handleOffset), GetCurrentProcess(), (HANDLE *)&hSock, STANDARD_RIGHTS_REQUIRED,TRUE,0);

            if(ret == 0)
            {
            int errcode = GetLastError();
            continue;
            }
            sockaddr_in in = {0};
            in.sin_family = AF_INET;
            int dwSize = sizeof(in);
            if(SOCKET_ERROR != getsockname(hSock, (sockaddr *)&in, &dwSize))
            {
            char name[0x100] = {0};

            HMODULE hDll = LoadLibrary("psapi.dll");
            typedef DWORD (WINAPI *PGETMODULEFILENAMEEX)(HANDLE, HMODULE, LPTSTR, DWORD);
            //typedef BOOL (WINAPI *PENUMPROCESSMODULES)(HANDLE, HMODULE*, DWORD, LPDWORD);
            PGETMODULEFILENAMEEX pfunc = (PGETMODULEFILENAMEEX)GetProcAddress(hDll, "GetModuleFileNameExA");
            //PENUMPROCESSMODULES penum = (PENUMPROCESSMODULES)GetProcAddress(hDll, "EnumProcessModules");
            //DWORD dwCb, dwRet;
            //HMODULE module[1000];
            //ret = penum(hSrcProcess

            pfunc(hSrcProcess, NULL, name, 0x100);


            FreeLibrary(hDll);

            printf("socket:%4d? port:%4d? PID:%4d(%s)\n", pSeek->handleOffset, ntohs(in.sin_port), pSeek->wPid, name);

            }
            }
            __finally
            {
            CloseHandle(hSrcProcess);
            }
            }

            }

            getchar();

            end:
            delete [] buf;
            return 0;
            }

            ?

            本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/hwman/archive/2005/01/14/254120.aspx

            久久精品国产亚洲AV大全| 久久久久久无码国产精品中文字幕 | 亚洲国产精品一区二区三区久久| 国内精品欧美久久精品| 99久久精品国产综合一区| 99久久精品无码一区二区毛片| 情人伊人久久综合亚洲| 久久久青草青青国产亚洲免观| 色婷婷综合久久久久中文字幕| 久久天天躁狠狠躁夜夜2020一| 久久亚洲精品中文字幕| 99久久国产综合精品麻豆| 亚洲国产精品高清久久久| 久久99热精品| 日本加勒比久久精品| 久久久久亚洲AV无码网站| 久久午夜福利电影| 国产美女久久精品香蕉69| 亚洲国产成人久久精品99| 久久综合国产乱子伦精品免费| 青青草国产精品久久久久| 国产精品乱码久久久久久软件 | 伊人久久五月天| 久久久噜噜噜www成人网| 久久伊人影视| 久久婷婷国产麻豆91天堂| 97视频久久久| 99久久婷婷国产一区二区| 国产成人精品综合久久久久| 久久精品国产一区二区电影| 亚洲国产另类久久久精品小说| 久久精品亚洲乱码伦伦中文| 久久人爽人人爽人人片AV| 国内精品伊人久久久影院| 99热都是精品久久久久久| 久久天堂AV综合合色蜜桃网| 久久久这里有精品| 人人妻久久人人澡人人爽人人精品 | 18岁日韩内射颜射午夜久久成人| 狠狠色丁香婷婷综合久久来来去| 国产亚洲欧美成人久久片 |