vc6编译gettcptable
来源:互联网 发布:伊布 知乎 编辑:程序博客网 时间:2024/06/04 18:26
微软官方例程
#include <winsock2.h>
#include <ws2tcpip.h>
#include <iphlpapi.h>
#include <stdio.h>
// Need to link with Iphlpapi.lib and Ws2_32.lib
#define MALLOC(x) HeapAlloc(GetProcessHeap(), 0, (x))
#define FREE(x) HeapFree(GetProcessHeap(), 0, (x))
/* Note: could also use malloc() and free() */
int main()
{
// Declare and initialize variables
PMIB_TCPTABLE pTcpTable;
DWORD dwSize = 0;
DWORD dwRetVal = 0;
char szLocalAddr[128];
char szRemoteAddr[128];
struct in_addr IpAddr;
int i;
pTcpTable = (MIB_TCPTABLE *) MALLOC(sizeof (MIB_TCPTABLE));
if (pTcpTable == NULL) {
printf("Error allocating memory/n");
return 1;
}
dwSize = sizeof (MIB_TCPTABLE);
// Make an initial call to GetTcpTable to
// get the necessary size into the dwSize variable
if ((dwRetVal = GetTcpTable(pTcpTable, &dwSize, TRUE)) ==
ERROR_INSUFFICIENT_BUFFER) {
FREE(pTcpTable);
pTcpTable = (MIB_TCPTABLE *) MALLOC(dwSize);
if (pTcpTable == NULL) {
printf("Error allocating memory/n");
return 1;
}
}
// Make a second call to GetTcpTable to get
// the actual data we require
if ((dwRetVal = GetTcpTable(pTcpTable, &dwSize, TRUE)) == NO_ERROR) {
printf("/tNumber of entries: %d/n", (int) pTcpTable->dwNumEntries);
for (i = 0; i < (int) pTcpTable->dwNumEntries; i++) {
IpAddr.S_un.S_addr = (u_long) pTcpTable->table[i].dwLocalAddr;
strcpy_s(szLocalAddr, sizeof (szLocalAddr), inet_ntoa(IpAddr));
IpAddr.S_un.S_addr = (u_long) pTcpTable->table[i].dwRemoteAddr;
strcpy_s(szRemoteAddr, sizeof (szRemoteAddr), inet_ntoa(IpAddr));
printf("/n/tTCP[%d] State: %ld - ", i,
pTcpTable->table[i].dwState);
switch (pTcpTable->table[i].dwState) {
case MIB_TCP_STATE_CLOSED:
printf("CLOSED/n");
break;
case MIB_TCP_STATE_LISTEN:
printf("LISTEN/n");
break;
case MIB_TCP_STATE_SYN_SENT:
printf("SYN-SENT/n");
break;
case MIB_TCP_STATE_SYN_RCVD:
printf("SYN-RECEIVED/n");
break;
case MIB_TCP_STATE_ESTAB:
printf("ESTABLISHED/n");
break;
case MIB_TCP_STATE_FIN_WAIT1:
printf("FIN-WAIT-1/n");
break;
case MIB_TCP_STATE_FIN_WAIT2:
printf("FIN-WAIT-2 /n");
break;
case MIB_TCP_STATE_CLOSE_WAIT:
printf("CLOSE-WAIT/n");
break;
case MIB_TCP_STATE_CLOSING:
printf("CLOSING/n");
break;
case MIB_TCP_STATE_LAST_ACK:
printf("LAST-ACK/n");
break;
case MIB_TCP_STATE_TIME_WAIT:
printf("TIME-WAIT/n");
break;
case MIB_TCP_STATE_DELETE_TCB:
printf("DELETE-TCB/n");
break;
default:
printf("UNKNOWN dwState value/n");
break;
}
printf("/tTCP[%d] Local Addr: %s/n", i, szLocalAddr);
printf("/tTCP[%d] Local Port: %d /n", i,
ntohs((u_short)pTcpTable->table[i].dwLocalPort));
printf("/tTCP[%d] Remote Addr: %s/n", i, szRemoteAddr);
printf("/tTCP[%d] Remote Port: %d/n", i,
ntohs((u_short)pTcpTable->table[i].dwRemotePort));
}
} else {
printf("/tGetTcpTable failed with %d/n", dwRetVal);
FREE(pTcpTable);
return 1;
}
return 0;
}
csdn例程
#include "Iphlpapi.h"
#include <malloc.h>
#include "Winsock2.h"
#include <stdlib.h>
#pragma comment(lib, "Iphlpapi.lib")
#pragma comment(lib, "ws2_32.lib")
static char TcpState[][32] =
{
"???",
"CLOSED",
"LISTENING",
"SYN_SENT",
"SEN_RECEIVED",
"ESTABLISHED",
"FIN_WAIT",
"FIN_WAIT2",
"CLOSE_WAIT",
"CLOSING",
"LAST_ACK",
"TIME_WAIT"
};
DWORD EnumTCPTable()
{
PMIB_TCPTABLE pTcpTable = NULL;
DWORD dwSize = 0;
DWORD dwRetVal = ERROR_SUCCESS;
struct in_addr rip;
struct in_addr lip;
char szrip[32] = {0};
char szlip[32] = {0};
//获得pTcpTable所需要的真实长度,dwSize
if (GetTcpTable(pTcpTable, &dwSize, TRUE) == ERROR_INSUFFICIENT_BUFFER)
{
pTcpTable = (MIB_TCPTABLE*) malloc ((UINT) dwSize);
}
else
return dwRetVal;
printf("Active Connections/n/n");
printf(" Proto/t%-24s%-24s%s/n","Local Address","Foreign Address","State");
if ((dwRetVal = GetTcpTable(pTcpTable, &dwSize, TRUE)) == NO_ERROR)
{
for (int i = 0; i < (int) pTcpTable->dwNumEntries; i++)
{
rip.S_un.S_addr = pTcpTable->table[i].dwRemoteAddr;
lip.S_un.S_addr = pTcpTable->table[i].dwLocalAddr;
//监听端口,远程主机端口为0,但函数返回是有值的,不知道它是怎么考虑的
if (pTcpTable->table[i].dwState == MIB_TCP_STATE_LISTEN)
pTcpTable->table[i].dwRemotePort = 0;
//dwLocalPort,dwRemotePort 是网络字节
_snprintf(szlip,sizeof(szlip),"%s:%d",inet_ntoa(lip),htons((u_short)pTcpTable->table[i].dwLocalPort));
_snprintf(szrip,sizeof(szrip),"%s:%d",inet_ntoa(rip),htons((u_short)pTcpTable->table[i].dwRemotePort));
printf(" TCP/t%-24s%-24s%s/n",szlip,szrip,TcpState[pTcpTable->table[i].dwState]);
}
}
else
{
printf("/tCall to GetTcpTable failed./n");
LPVOID lpMsgBuf;
if (FormatMessage(
FORMAT_MESSAGE_ALLOCATE_BUFFER |
FORMAT_MESSAGE_FROM_SYSTEM |
FORMAT_MESSAGE_IGNORE_INSERTS,
NULL,
dwRetVal,
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language
(LPTSTR) &lpMsgBuf,
0,
NULL ))
{
printf("/tError: %s", lpMsgBuf);
}
LocalFree( lpMsgBuf );
}
GlobalFree(pTcpTable);
return dwRetVal;
}
DWORD DelTCPConnect(const char *lpszLocalAddr,
const char * lpszRemoteAddr,
DWORD dwLocalPort,
DWORD dwRemotePort)
{
DWORD dwRetVal = ERROR_NOT_FOUND;
MIB_TCPROW srtTcpRow;
srtTcpRow.dwLocalAddr = inet_addr(lpszLocalAddr);
srtTcpRow.dwRemoteAddr = inet_addr(lpszRemoteAddr);
srtTcpRow.dwLocalPort = htons(dwLocalPort);
srtTcpRow.dwRemotePort = htons(dwRemotePort);
srtTcpRow.dwState = MIB_TCP_STATE_DELETE_TCB; //目前为止,settcpEntry只支持该参数
dwRetVal = SetTcpEntry(&srtTcpRow);
if (dwRetVal != ERROR_SUCCESS)
{
LPVOID lpMsgBuf;
if (FormatMessage(
FORMAT_MESSAGE_ALLOCATE_BUFFER |
FORMAT_MESSAGE_FROM_SYSTEM |
FORMAT_MESSAGE_IGNORE_INSERTS,
NULL,
dwRetVal,
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language
(LPTSTR) &lpMsgBuf,
0,
NULL ))
{
printf("/tError: %s", lpMsgBuf);
}
LocalFree( lpMsgBuf );
}
return dwRetVal;
}
vc6编译时,产生如下错误:
wspiapi.h(45) : error C2265: '<Unknown>' : reference to a zero-sized array is illegal.
编写IP多播程序时,要用到ip_mrep结构,在编译时会遇到如下的错误:
/include/wspiapi.h(45) : error C2265: '<Unknown>' : reference to a zero-sized array is illegal.
这种错误是由于wspiapi.h头文件里缺少#define _WSPIAPI_COUNTOF语句造成的.
找到你安装的platformsdk/include目录下的WS2tcpip.h头文件
解决办法是在#include <wspiapi.h>之前#define _WSPIAPI_COUNTOF
具体代码如下:
#if !defined(_WIN32_WINNT) || (_WIN32_WINNT <= 0x0500)
#define _WSPIAPI_COUNTOF
#include <wspiapi.h>
#endif
- vc6编译gettcptable
- GetTCPTable,SetTCPTable的函数
- 配置vc6编译驱动程序
- VC6常用编译指令
- 用Vc6编译GuitoolKit
- VC6常用编译指令
- VC6编译XVID
- VC6中编译参数设置
- VC6中编译参数设置
- VC6.0下编译
- VC6中编译参数设置
- VC6.0 编译 XVid
- vc6下编译汇编程序
- VC6编译LibCurl
- 批处理编译vc6工程
- VC6编译 Quake3 游戏
- VC6中编译参数设置
- VC6编译错误解决
- 动态插入子菜单(ID不定)(MFC)
- SQL Server:定时作业的设置方法
- java常见错误以及可能原因集锦
- SQL语句精品收藏
- close_wait状态和time_wait状态
- vc6编译gettcptable
- [转载]大型项目管理的容易忽略的一些问题
- java webservice AXIS安装及应用
- 项目管理实践【六】自动同步数据库
- Create New release Role detail information
- 项目管理实践【五】自动编译和发布网站
- 项目管理实践【三】每日构建
- 项目管理实践教程二、源代码控制
- 项目管理实践一 工具