所以我试着为此寻找几个不同的答案。我认为可能有希望的是这一个:
How to check network interface type is Ethernet or Wireless on Windows using Qt?
但是,我对网络甚至Windows都不太了解。就个人而言,我无法理解他们网站上的大多数Microsoft文档。我尝试了INetworkConnection
,NativeWiFi
等等。但要么他们没有做我想做的事情,要么我无法从可用的文档中弄清楚如何做到这一点。
话虽如此,我想用C ++来检查这个程序运行的设备是否通过以太网线连接到互联网。基本上,我想做以下事情:
然而,问题是我不知道如何检查设备是否已连接以太网。有没有办法做到这一点?我没有使用QT。谢谢!
编辑:我还应该包括我到目前为止所尝试的内容。我尝试使用GetAdaptersInfo
并从Type
变量类型获取PIP_ADAPTER_INFO
特征,但这总是给我Unknown type 71
我是否在以太网上。
GetAdaptersInfo
的文档在这里:
https://msdn.microsoft.com/en-us/library/aa365917%28VS.85%29.aspx
由于
编辑2:这是我用于GetAdaptersInfo的代码
bool is_on_ethernet{
PIP_ADAPTER_INFO pAdapterInfo;
PIP_ADAPTER_INFO pAdapter = NULL;
DWORD dwRetVal = 0;
UINT i;
struct tm newtime;
char buffer[32];
errno_t error;
ULONG ulOutBufLen = sizeof(IP_ADAPTER_INFO);
pAdapterInfo = (IP_ADAPTER_INFO *)malloc(sizeof(IP_ADAPTER_INFO));
if(pAdapterInfo == NULL)
printf("Error allocating memory need to call GetAdaptersInfo");
if(GetAdaptersInfo(pAdapterInfo, &ulOutBufLen) == ERROR_BUFFER_OVERFLOW){
free(pAdapterInfo);
pAdapterInfo = (IP_ADAPTER_INFO *)malloc(ulOutBufLen);
}
if((dwRetVal = GetAdaptersInfo(pAdapterInfo, &ulOutBufLen)) == NO_ERROR){
pAdapter = pAdapterInfo;
switch(pAdapter->Type){
case MIB_IF_TYPE_OTHER:
printf("Other\n");
return false;
break;
case MIB_IF_TYPE_ETHERNET:
printf("Ethernet\h");
return true;
break;
case MIB_IF_TYPE_TOKENRING:
printf("Token Ring\n");
return false;
break;
case MIB_IF_TYPE_FDDI
printf("FDDI\n");
return false;
break;
case MIB_IF_TYPE_PPP
printf("PPP\n");
return false;
break;
case MIB_IF_TYPE_LOOPBACK
printf("Lookback\n");
return false;
break;
case MIB_IF_TYPE_SLIP
printf("Slip\n");
return false;
break;
default
printf("Unknown type %ld\n\n", pAdapter->Type);
return false;
break;
}
}
if(pAdapterInfo)
free(pAdapterInfo);
return false;
}
答案 0 :(得分:0)
基于@specializt的回答,并做了一些小的修改,我对它的工作如下:
BOOL getDevices(NDIS_PHYSICAL_MEDIUM type, vector<MIB_IF_ROW2>& vetIFRow)
{
PMIB_IF_TABLE2 table = NULL;
if (GetIfTable2Ex(MibIfTableRaw, &table) != NOERROR || !table)
{
return FALSE;
}
for (ULONG i = 0; i < table->NumEntries; i++)
{
MIB_IF_ROW2 row;
ZeroMemory(&row, sizeof(MIB_IF_ROW2));
row.InterfaceIndex = i;
if (GetIfEntry2(&row) == NOERROR && row.PhysicalMediumType == type)
{
vetIFRow.push_back(row);
}
}
FreeMibTable(table);
return TRUE;
}
BOOL isNetIFConnected(const MIB_IF_ROW2& row, IFTYPE Type)
{
return (row.TunnelType == TUNNEL_TYPE_NONE &&
row.AccessType != NET_IF_ACCESS_LOOPBACK &&
row.Type == Type &&
row.InterfaceAndOperStatusFlags.HardwareInterface == TRUE &&
row.MediaConnectState == MediaConnectStateConnected);
}
tstring getNetWorkType()
{
vector<MIB_IF_ROW2> vectRow;
BOOL bRet = getDevices(NdisPhysicalMedium802_3, vectRow); // ETHERNET adapters
if (bRet)
{
for (auto it = vectRow.begin(); it != vectRow.end(); it++)
{
if (isNetIFConnected(*it, IF_TYPE_ETHERNET_CSMACD))
{
return L"ETHERNET";
}
}
}
vectRow.clear();
bRet = getDevices(NdisPhysicalMediumNative802_11, vectRow); //WLAN adapters
if (bRet)
{
for (auto it = vectRow.begin(); it != vectRow.end(); it++)
{
if (isNetIFConnected(*it, IF_TYPE_IEEE80211))
{
return L"WIFI";
}
}
}
return L"Unknown";
}
感谢@specializt