大文

关注C\C++开发与架构

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

一台机器上可能有多个网卡,每一个网卡只有一个MAC地址,但是每一个网卡可能配置有多个IP地址;如平常的笔记本电脑中,就会有无线网卡和有线网卡(网线接口)两种;因此,如果要获得本机所有网卡的IP和MAC地址信息,则必须顺序获得每个网卡,再依次获取其信息等;在windows sdk中,用IP_ADAPTER_INFO结构体存储网卡信息,包括网卡名、网卡描述、网卡MAC地址、网卡IP等,该结构体的主要描述如下所示:

typedef struct _IP_ADAPTER_INFO

struct _IP_ADAPTER_INFO* Next;  //指向同类型节点,即下一个网卡(如果有多个的话)

char AdapterName[MAX_ADAPTER_NAME_LENGTH +4];  //网卡名

charDescription[MAX_ADAPTER_DESCRIPTION_LENGTH + 4]; //网卡描述信息

UINT AddressLength; //网卡MAC长度

BYTEAddress[MAX_ADAPTER_ADDRESS_LENGTH];  //网卡MAC地址

IP_ADDR_STRING IpAddressList;  //网卡IP列表

…………….

…………….

} IP_ADAPTER_INFO,

由于可能有多个网卡,因此struct _IP_ADAPTER_INFO* Next字段为一个链表结构指针,由于一个网卡可能有多个IP,因此IP_ADDR_STRING字段应该也是一个链表结构,其信息如下所示:

typedef struct _IP_ADDR_STRING

{

struct _IP_ADDR_STRING* Next;  //指向同类型节点,即下一个IP(如果有多IP的话)

IP_ADDRESS_STRING IpAddress;  //IP地址信息

IP_MASK_STRING IpMask; 

DWORD Context;

} IP_ADDR_STRING,

IP_ADDR_STRING结构也是一个链表节点

综上所述,用下图来描述网卡的结构存储信息,也许更明朗:

-----------------------------------------------------------------------------------------------------------------------------------

直接上代码(注意代码工程需要链接Iphlpapi.lib库):

 

// 头文件包含
#include "stdafx.h"
#include
<WinSock2.h>
#include
<Iphlpapi.h>
#include
<iostream>
using namespace std;
// 函数声明
void output(PIP_ADAPTER_INFO pIpAdapterInfo);
// 程序入口
int _tmain(int argc, _TCHAR* argv[])
{
//PIP_ADAPTER_INFO结构体指针存储本机网卡信息
PIP_ADAPTER_INFO pIpAdapterInfo = new IP_ADAPTER_INFO();
//得到结构体大小,用于GetAdaptersInfo参数
unsigned long stSize = sizeof(IP_ADAPTER_INFO);
//调用GetAdaptersInfo函数,填充pIpAdapterInfo指针变量;其中stSize参数既是一个输入量也是一个输出量
int nRel = GetAdaptersInfo(pIpAdapterInfo,&stSize);
if (ERROR_BUFFER_OVERFLOW==nRel)
{
 
//如果函数返回的是ERROR_BUFFER_OVERFLOW
    //则说明GetAdaptersInfo参数传递的内存空间不够,同时其传出stSize,表示需要的空间大小
//这也是说明为什么stSize既是一个输入量也是一个输出量
//释放原来的内存空间
delete pIpAdapterInfo;
//重新申请内存空间用来存储所有网卡信息
pIpAdapterInfo = (PIP_ADAPTER_INFO)new BYTE[stSize];
//再次调用GetAdaptersInfo函数,填充pIpAdapterInfo指针变量
nRel=GetAdaptersInfo(pIpAdapterInfo,&stSize);
}
if (ERROR_SUCCESS==nRel)
{
//输出网卡信息
output(pIpAdapterInfo);
}
//释放内存空间
if (pIpAdapterInfo)
{
delete pIpAdapterInfo;
}
getchar();
return 0;
}
///函数作用,输出网卡信息
void output(PIP_ADAPTER_INFO pIpAdapterInfo)
{
//可能有多网卡,因此通过循环去判断
while (pIpAdapterInfo)
{
cout
<<"网卡名称:"<<pIpAdapterInfo->AdapterName<<endl;
cout
<<"网卡描述:"<<pIpAdapterInfo->Description<<endl;
cout
<<"网卡MAC地址:"<<pIpAdapterInfo->Address;
for (UINT i = 0; i < pIpAdapterInfo->AddressLength; i++)
if (i==pIpAdapterInfo->AddressLength-1)
{
printf(
"%02x\n", pIpAdapterInfo->Address[i]);
}
else
{
printf(
"%02x-", pIpAdapterInfo->Address[i]);
}
cout
<<"网卡IP地址如下:"<<endl;
//可能网卡有多IP,因此通过循环去判断
IP_ADDR_STRING *pIpAddrString =&(pIpAdapterInfo->IpAddressList);
do
{
cout
<<pIpAddrString->IpAddress.String<<endl;
pIpAddrString
=pIpAddrString->Next;
}
while (pIpAddrString);
pIpAdapterInfo
= pIpAdapterInfo->Next;
cout
<<"*****************************************************"<<endl;
}
return;
}

 

程序运行结果如下图所示:

posted on 2010-10-03 23:50  大文  阅读(22992)  评论(0编辑  收藏  举报