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

            日韩精品久久久久久| 色狠狠久久综合网| 99久久综合狠狠综合久久| 久久精品国产精品亚洲下载| 伊人热热久久原色播放www| 久久婷婷国产综合精品| 91精品国产91久久久久久| 久久人妻无码中文字幕| 国产精品青草久久久久福利99| 久久久久久久97| 久久精品国产一区二区 | 久久se精品一区二区| 久久久久综合国产欧美一区二区| 久久精品免费一区二区| 91精品国产91久久久久久| 亚洲精品无码久久久久去q| 久久婷婷国产麻豆91天堂| 久久婷婷人人澡人人爽人人爱| 国产精品久久久久9999高清| 久久久久精品国产亚洲AV无码| 99久久国产主播综合精品| www性久久久com| 无码国产69精品久久久久网站| 日韩美女18网站久久精品| 久久精品免费一区二区三区| 久久久久高潮毛片免费全部播放| 内射无码专区久久亚洲| 国产精品内射久久久久欢欢| 狠狠狠色丁香婷婷综合久久俺| 久久精品国产99久久无毒不卡| 囯产极品美女高潮无套久久久| 精品久久久久久久久免费影院| 香蕉久久影院| 久久99久久99精品免视看动漫| 蜜桃麻豆WWW久久囤产精品| 国产免费久久精品99re丫y| 伊人精品久久久久7777| 国内精品久久久久久久久电影网 | 久久久久99精品成人片牛牛影视| 久久久久综合网久久| 精品欧美一区二区三区久久久 |