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

            久久777国产线看观看精品| 久久综合狠狠综合久久97色| 99久久做夜夜爱天天做精品| 亚洲精品NV久久久久久久久久| 久久午夜无码鲁丝片秋霞| 久久国产精品一国产精品金尊| 久久久青草久久久青草| 久久毛片免费看一区二区三区| 亚洲欧美日韩久久精品第一区| 国产人久久人人人人爽| 色综合久久88色综合天天 | 亚洲精品乱码久久久久久久久久久久 | 少妇精品久久久一区二区三区| 欧美黑人激情性久久| 国内精品久久久久久久亚洲| 亚洲国产精品无码久久久秋霞2 | 波多野结衣久久一区二区| 2022年国产精品久久久久| 99久久香蕉国产线看观香| 国产精品久久亚洲不卡动漫| 久久综合偷偷噜噜噜色| 品成人欧美大片久久国产欧美| 一本色道久久99一综合| 欧美久久久久久午夜精品| 伊人久久大香线焦综合四虎| 亚洲va久久久噜噜噜久久天堂| 久久97久久97精品免视看秋霞| 久久亚洲春色中文字幕久久久| 亚洲欧美国产日韩综合久久| 国产午夜精品久久久久九九| 国产亚洲精品自在久久| 久久亚洲私人国产精品vA| 伊人久久大香线蕉亚洲| 伊人 久久 精品| 久久夜色精品国产噜噜亚洲a| 久久久久亚洲av成人无码电影 | 久久精品国产亚洲AV久 | 久久久高清免费视频| 久久高清一级毛片| 久久久久久亚洲精品无码| 久久狠狠一本精品综合网|