• <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国产欧美精品久久久蜜芽| 成人久久久观看免费毛片 | 亚洲国产精品高清久久久| 无码国内精品久久人妻| av午夜福利一片免费看久久| 国产精品成人无码久久久久久 | 一本久久a久久精品vr综合| 午夜精品久久久久久久| 亚洲国产精品久久久久婷婷软件 | 色综合久久夜色精品国产| 亚洲日本va中文字幕久久| 色综合久久88色综合天天| 日韩精品无码久久一区二区三| 久久一日本道色综合久久| 99热热久久这里只有精品68| 久久这里有精品视频| www.久久热.com| 蜜桃麻豆WWW久久囤产精品| 伊人色综合久久天天| 精品久久久无码人妻中文字幕| 91精品国产乱码久久久久久| 婷婷国产天堂久久综合五月| 久久久久夜夜夜精品国产| 久久久久久精品久久久久| 国产精久久一区二区三区| 国内精品久久久久影院优 | 国产精品久久久久蜜芽| 久久―日本道色综合久久| 青青草原综合久久大伊人| 久久久久亚洲AV成人网| 久久久精品国产sm调教网站 | 亚洲精品无码成人片久久| 亚洲国产精品无码久久九九 | 国产精品久久久久蜜芽| 深夜久久AAAAA级毛片免费看| 一本色道久久88加勒比—综合| 热re99久久精品国99热| 亚洲中文字幕无码久久2020|