Поделиться через


структура MIB_UNICASTIPADDRESS_ROW (netioapi.h)

В структуре MIB_UNICASTIPADDRESS_ROW хранятся сведения об одноадресном IP-адресе.

Синтаксис

typedef struct _MIB_UNICASTIPADDRESS_ROW {
  SOCKADDR_INET    Address;
  NET_LUID         InterfaceLuid;
  NET_IFINDEX      InterfaceIndex;
  NL_PREFIX_ORIGIN PrefixOrigin;
  NL_SUFFIX_ORIGIN SuffixOrigin;
  ULONG            ValidLifetime;
  ULONG            PreferredLifetime;
  UINT8            OnLinkPrefixLength;
  BOOLEAN          SkipAsSource;
  NL_DAD_STATE     DadState;
  SCOPE_ID         ScopeId;
  LARGE_INTEGER    CreationTimeStamp;
} MIB_UNICASTIPADDRESS_ROW, *PMIB_UNICASTIPADDRESS_ROW;

Члены

Address

Тип: SOCKADDR_INET

IP-адрес одноадресной рассылки. Это может быть IPv6-адрес или IPv4-адрес.

InterfaceLuid

Тип: NET_LUID

Локальный уникальный идентификатор (LUID) для сетевого интерфейса, связанного с этим IP-адресом.

InterfaceIndex

Тип: NET_IFINDEX

Значение локального индекса для сетевого интерфейса, связанного с этим IP-адресом. Это значение индекса может изменяться при отключении и включении сетевого адаптера или при других обстоятельствах и не должно считаться постоянным.

PrefixOrigin

Тип: NL_PREFIX_ORIGIN

Источник префикса или сетевой части IP-адреса. Этот элемент может быть одним из значений из типа перечисления NL_PREFIX_ORIGIN , определенного в файле заголовка Nldef.h .

Значение Значение
IpPrefixOriginOther
0
Префикс IP-адреса был настроен с помощью источника, отличного от тех, которые определены в этом перечислении. Это значение применимо к IPv6- или IPv4-адресу.
IpPrefixOriginManual
1
Префикс IP-адреса был настроен вручную. Это значение применимо к IPv6- или IPv4-адресу.
IpPrefixOriginWellKnown
2
Префикс IP-адреса был настроен с помощью известного адреса. Это значение применимо к локальному адресу канала IPv6 или адресу замыкания на себя IPv6.
IpPrefixOriginDhcp
3
Префикс IP-адреса был настроен с помощью DHCP. Это значение применимо к IPv4-адресу, настроенного с помощью DHCP, или IPv6-адресу, настроенного с помощью DHCPv6.
IpPrefixOriginRouterAdvertisement
4
Префикс IP-адреса был настроен с помощью объявления маршрутизатора. Это значение применимо к анонимному IPv6-адресу, созданному после получения объявления маршрутизатора.
IpPrefixOriginUnchanged
16
Префикс IP-адреса должен быть без изменений. Это значение используется при задании свойств для одноадресного IP-интерфейса, когда значение источника префикса IP-адреса должно быть неизменным.

SuffixOrigin

Тип: NL_SUFFIX_ORIGIN

Источник суффикса или части узла IP-адреса. Этот элемент может быть одним из значений из типа перечисления NL_SUFFIX_ORIGIN, определенного в файле заголовка Nldef.h .

Значение Значение
IpSuffixOriginOther
0
Суффикс IP-адреса был настроен с использованием источника, отличного от тех, которые определены в этом перечислении. Это значение применимо к IPv6- или IPv4-адресу.
IpSuffixOriginManual
1
Суффикс IP-адреса был настроен вручную. Это значение применимо к IPv6- или IPv4-адресу.
IpSuffixOriginWellKnown
2
Суффикс IP-адреса был настроен с помощью известного адреса. Это значение применимо к локальному адресу канала IPv6 или адресу замыкания на себя IPv6.
IpSuffixOriginDhcp
3
Суффикс IP-адреса был настроен с помощью DHCP. Это значение применимо к IPv4-адресу, настроенного с помощью DHCP, или IPv6-адресу, настроенного с помощью DHCPv6.
IpSuffixOriginLinkLayerAddress
4
Суффикс IP-адреса был локальным адресом ссылки. Это значение применимо к локальному адресу канала IPv6 или IPv6-адресу, где сетевая часть была создана на основе объявления маршрутизатора, а часть узла была основана на аппаратном MAC-адресе.
IpSuffixOriginRandom
5
Суффикс IP-адреса был создан случайным образом. Это значение применимо к анонимному IPv6-адресу, где часть адреса узла была создана случайным образом из аппаратного MAC-адреса после получения объявления маршрутизатора.
IpSuffixOriginUnchanged
16
Суффикс IP-адреса должен быть без изменений. Это значение используется при настройке свойств для одноадресного IP-интерфейса, когда значение источника IP-суффикса должно быть неизменным.

ValidLifetime

Тип: ULONG

Максимальное время (в секундах) допустимости IP-адреса. Значение 0xffffffff считается бесконечным.

PreferredLifetime

Тип: ULONG

Предпочтительное время (в секундах), когда IP-адрес является допустимым. Значение 0xffffffff считается бесконечным.

OnLinkPrefixLength

Тип: UINT8

Длина (в битах) префикса или сетевой части IP-адреса. Для одноадресного IPv4-адреса любое значение больше 32 является недопустимым. Для одноадресного IPv6-адреса любое значение больше 128 является недопустимым. Значение 255 обычно используется для представления недопустимого значения.

SkipAsSource

Тип: BOOLEAN

Этот элемент указывает, можно ли использовать адрес в качестве исходного IP-адреса.

DadState

Тип: NL_DAD_STATE

Состояние обнаружения повторяющихся адресов (DAD). Обнаружение повторяющихся адресов применимо к адресам IPv6 и IPv4. Этот элемент может быть одним из значений из типа перечисления NL_DAD_STATE, определенного в файле заголовка Nldef.h .

Значение Значение
IpDadStateInvalid
0
Недопустимое состояние DAD.
IpDadStateTentative
1
Состояние DAD является предварительным.
IpDadStateDuplicate
2
Обнаружены повторяющиеся IP-адреса.
IpDadStateDeprecated
3
IP-адрес не рекомендуется использовать.
IpDadStatePreferred
4
Ip-адрес является предпочтительным.

ScopeId

Тип: SCOPE_ID

Идентификатор область IP-адреса. Этот член применим только к IPv6-адресу. Этот элемент не может быть задан. Он автоматически определяется интерфейсом, в котором был добавлен адрес.

CreationTimeStamp

Тип: LARGE_INTEGER

Метка времени создания IP-адреса.

Комментарии

Структура MIB_UNICASTIPADDRESS_ROW определяется в Windows Vista и более поздних версиях.

Элемент SkipAsSource структуры MIB_UNICASTIPADDRESS_ROW влияет на работу функций getaddrinfo, GetAddrInfoW и GetAddrInfoEx в сокетах Windows. Если параметр pNodeName , переданный в функции getaddrinfo или GetAddrInfoW , или параметр pName , переданный функции GetAddrInfoEx , указывает на имя компьютера, возвращаются все постоянные адреса компьютера, которые можно использовать в качестве исходного адреса. В Windows Vista и более поздних версиях эти адреса будут включать все одноадресные IP-адреса, возвращаемые функциями GetUnicastIpAddressTable или GetUnicastIpAddressEntry , в которых член SkipAsSource имеет значение false в структуре MIB_UNICASTIPADDRESS_ROW .

Если параметр pNodeName или pName ссылается на имя виртуального сервера кластера, возвращаются только адреса виртуальных серверов. В Windows Vista и более поздних версиях эти адреса будут включать все одноадресные IP-адреса, возвращаемые функциями GetUnicastIpAddressTable или GetUnicastIpAddressEntry , в которых член SkipAsSource имеет значение true в структуре MIB_UNICASTIPADDRESS_ROW . Дополнительные сведения о кластеризация см. в разделе Кластеризация Windows.

Windows 7 с пакетом обновления 1 (SP1) и Windows Server 2008 R2 с пакетом обновления 1 (SP1) поддерживают Netsh.exe для настройки атрибута SkipAsSource для IP-адреса. Это исправление также изменяет поведение таким образом, что если член SkipAsSource в структуре MIB_UNICASTIPADDRESS_ROW имеет значение false, IP-адрес будет зарегистрирован в DNS. Если для элемента SkipAsSource задано значение true, IP-адрес не регистрируется в DNS.

Доступно исправление для Windows 7 и Windows Server 2008 R2, которое добавляет поддержку Netsh.exe для задания атрибута SkipAsSource для IP-адреса. Это исправление также изменяет поведение таким образом, что если член SkipAsSource в структуре MIB_UNICASTIPADDRESS_ROW имеет значение false, IP-адрес будет зарегистрирован в DNS. Если для элемента SkipAsSource задано значение true, IP-адрес не регистрируется в DNS. Дополнительные сведения см. в статье База знаний (KB) 2386184.

Аналогичное исправление также доступно для Windows Vista с пакетом обновления 2 (SP2) и Windows Server 2008 с пакетом обновления 2 (SP2), которое добавляет поддержку Netsh.exe для задания атрибута SkipAsSource в IP-адресе. Это исправление также изменяет поведение таким образом, что если член SkipAsSource в структуре MIB_UNICASTIPADDRESS_ROW имеет значение false, IP-адрес будет зарегистрирован в DNS. Если для элемента SkipAsSource задано значение true, IP-адрес не регистрируется в DNS.

Примеры

В следующем примере извлекается таблица одноадресных IP-адресов и выводится некоторые значения из каждой из полученных MIB_UNICASTIPADDRESS_ROW структур.


#ifndef UNICODE
#define UNICODE
#endif

#ifndef WIN32_LEAN_AND_MEAN
#define WIN32_LEAN_AND_MEAN
#endif

#include <Windows.h.>
#include <winsock2.h>
#include <ws2tcpip.h>
#include <ws2ipdef.h>
#include <iphlpapi.h>
#include <stdio.h>
#include <stdlib.h>

// Need to link with Iphlpapi.lib and Ws2_32.lib
#pragma comment (lib, "iphlpapi.lib")
#pragma comment (lib, "Ws2_32.lib")

int __cdecl wmain()
{

    // Declare and initialize variables

    unsigned int i;

    DWORD Result = 0;

    WCHAR Ipv4String[16] = { 0 };
    WCHAR Ipv6String[46] = { 0 };

    PMIB_UNICASTIPADDRESS_TABLE pipTable = NULL;

    Result = GetUnicastIpAddressTable(AF_UNSPEC, &pipTable);
    if (Result != NO_ERROR) {
        wprintf(L"GetUnicastIpAddressTable returned error: %ld\n", Result);
        exit(1);
    }
    // Print some variables from the rows in the table
    wprintf(L"Number of table entries: %d\n\n", pipTable->NumEntries);

    for (i = 0; i < pipTable->NumEntries; i++) {
        wprintf(L"AddressFamily[%d]:\t\t ", i);

        switch (pipTable->Table[i].Address.si_family) {
        case AF_INET:
            wprintf(L"IPv4\n");
            if (InetNtopW
                (AF_INET, &pipTable->Table[i].Address.Ipv4.sin_addr, Ipv4String,
                 16) != NULL)
                wprintf(L"IPv4 Address:\t\t\t %ws\n", Ipv4String);
            break;
        case AF_INET6:
            wprintf(L"IPv6\n");
            if (InetNtopW
                (AF_INET6, &pipTable->Table[i].Address.Ipv6.sin6_addr,
                 Ipv6String, 46) != NULL)
                wprintf(L"IPv6 Address:\t\t\t %ws\n", Ipv6String);
            break;
        default:
            wprintf(L"Other: %d\n", pipTable->Table[i].Address.si_family);
            break;
        }

        wprintf(L"Interface LUID NetLuidIndex[%d]:  %lu\n",
               i, pipTable->Table[i].InterfaceLuid.Info.NetLuidIndex);
        wprintf(L"Interface LUID IfType[%d]:\t ", i);
        switch (pipTable->Table[i].InterfaceLuid.Info.IfType) {
        case IF_TYPE_OTHER:
            wprintf(L"Other\n");
            break;
        case IF_TYPE_ETHERNET_CSMACD:
            wprintf(L"Ethernet\n");
            break;
        case IF_TYPE_ISO88025_TOKENRING:
            wprintf(L"Token ring\n");
            break;
        case IF_TYPE_PPP:
            wprintf(L"PPP\n");
            break;
        case IF_TYPE_SOFTWARE_LOOPBACK:
            wprintf(L"Software loopback\n");
            break;
        case IF_TYPE_ATM:
            wprintf(L"ATM\n");
            break;
        case IF_TYPE_IEEE80211:
            wprintf(L"802.11 wireless\n");
            break;
        case IF_TYPE_TUNNEL:
            wprintf(L"Tunnel encapsulation\n");
            break;
        case IF_TYPE_IEEE1394:
            wprintf(L"IEEE 1394 (Firewire)\n");
            break;
        default:
            wprintf(L"Unknown: %d\n",
                   pipTable->Table[i].InterfaceLuid.Info.IfType);
            break;
        }

        wprintf(L"Interface Index[%d]:\t\t %lu\n",
               i, pipTable->Table[i].InterfaceIndex);

        wprintf(L"Prefix Origin[%d]:\t\t ", i);
        switch (pipTable->Table[i].PrefixOrigin) {
        case IpPrefixOriginOther:
            wprintf(L"IpPrefixOriginOther\n");
            break;
        case IpPrefixOriginManual:
            wprintf(L"IpPrefixOriginManual\n");
            break;
        case IpPrefixOriginWellKnown:
            wprintf(L"IpPrefixOriginWellKnown\n");
            break;
        case IpPrefixOriginDhcp:
            wprintf(L"IpPrefixOriginDhcp\n");
            break;
        case IpPrefixOriginRouterAdvertisement:
            wprintf(L"IpPrefixOriginRouterAdvertisement\n");
            break;
        case IpPrefixOriginUnchanged:
            wprintf(L"IpPrefixOriginUnchanged\n");
            break;
        default:
            wprintf(L"Unknown: %d\n", pipTable->Table[i].PrefixOrigin);
            break;
        }

        wprintf(L"Suffix Origin[%d]:\t\t ", i);
        switch (pipTable->Table[i].SuffixOrigin) {
        case IpSuffixOriginOther:
            wprintf(L"IpSuffixOriginOther\n");
            break;
        case IpSuffixOriginManual:
            wprintf(L"IpSuffixOriginManual\n");
            break;
        case IpSuffixOriginWellKnown:
            wprintf(L"IpSuffixOriginWellKnown\n");
            break;
        case IpSuffixOriginDhcp:
            wprintf(L"IpSuffixOriginDhcp\n");
            break;
        case IpSuffixOriginLinkLayerAddress:
            wprintf(L"IpSuffixOriginLinkLayerAddress\n");
            break;
        case IpSuffixOriginRandom:
            wprintf(L"IpSuffixOriginRandom\n");
            break;
        case IpSuffixOriginUnchanged:
            wprintf(L"IpSuffixOriginUnchanged\n");
            break;
        default:
            wprintf(L"Unknown: %d\n", pipTable->Table[i].SuffixOrigin);
            break;
        }

        wprintf(L"Valid Lifetime[%d]:\t\t 0x%x (%u)\n", i,
               pipTable->Table[i].ValidLifetime,
               pipTable->Table[i].ValidLifetime);

        wprintf(L"Preferred Lifetime[%d]:\t\t 0x%x (%u)\n", i,
               pipTable->Table[i].PreferredLifetime,
               pipTable->Table[i].PreferredLifetime);

        wprintf(L"OnLink PrefixLength[%d]:\t\t %lu\n", i,
               pipTable->Table[i].OnLinkPrefixLength);

        wprintf(L"Skip As Source[%d]:\t\t ", i);
        if (pipTable->Table[i].SkipAsSource)
            wprintf(L"Yes\n");
        else
            wprintf(L"No\n");

        wprintf(L"Dad State[%d]:\t\t\t ", i);
        switch (pipTable->Table[i].DadState) {
        case IpDadStateInvalid:
            wprintf(L"IpDadStateInvalid\n");
            break;
        case IpDadStateTentative:
            wprintf(L"IpDadStateTentative\n");
            break;
        case IpDadStateDuplicate:
            wprintf(L"IpDadStateDuplicate\n");
            break;
        case IpDadStateDeprecated:
            wprintf(L"IpDadStateDeprecated\n");
            break;
        case IpDadStatePreferred:
            wprintf(L"IpDadStatePreferred\n");
            break;
        default:
            wprintf(L"Unknown: %d\n", pipTable->Table[i].DadState);
            break;
        }

        wprintf(L"\n");
    }

    if (pipTable != NULL) {
        FreeMibTable(pipTable);
        pipTable = NULL;
    }

    exit(0);
}


Требования

Требование Значение
Минимальная версия клиента Windows Vista [только классические приложения]
Минимальная версия сервера Windows Server 2008 [только классические приложения]
Верхняя часть netioapi.h (включая Iphlpapi.h)

См. также раздел

CreateUnicastIpAddressEntry

DeleteUnicastIpAddressEntry

GetAddrInfoEx

GetAddrInfoW

GetUnicastIpAddressEntry

GetUnicastIpAddressTable

InitializeUnicastIpAddressEntry

MIB_UNICASTIPADDRESS_TABLE

SOCKADDR_INET

SetUnicastIpAddressEntry

getaddrinfo