共用方式為


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

與此IP位址相關聯之網路介面的本機唯一標識碼 (LUID) 。

InterfaceIndex

類型: NET_IFINDEX

與此IP位址相關聯的網路介面本機索引值。 當網路適配器停用后啟用或在其他情況下,此索引值可能會變更,且不應視為持續性。

PrefixOrigin

類型: NL_PREFIX_ORIGIN

位址的前置詞或網路部分的來源。 這個成員可以是 Nldef.h 頭檔中所定義之NL_PREFIX_ORIGIN列舉類型的其中一個值。

意義
IpPrefixOriginOther
0
IP 位址前置詞是使用此列舉中所定義來源以外的來源來設定。 此值適用於 IPv6 或 IPv4 位址。
IpPrefixOriginManual
1
IP 位址前置詞已手動設定。 此值適用於 IPv6 或 IPv4 位址。
IpPrefixOriginWellKnown
2
IP 位址前置詞是使用已知的位址來設定的。 此值適用於 IPv6 連結本機位址或 IPv6 回送位址。
IpPrefixOriginDhcp
3
IP 位址前置詞是使用 DHCP 設定的。 此值適用於使用 DHCP 設定的 IPv4 位址,或使用 DHCPv6 設定的 IPv6 位址。
IpPrefixOriginRouterAdvertisement
4
IP 位址前置詞是使用路由器公告來設定的。 此值適用於接收路由器公告之後產生的匿名 IPv6 位址。
IpPrefixOriginUnchanged
16
IP 位址前置詞應保持不變。 當IP前置詞來源的值應保持不變時,設定單播IP介面的屬性時,就會使用此值。

SuffixOrigin

類型: NL_SUFFIX_ORIGIN

地址後綴或主機部分的來源。 這個成員可以是 Nldef.h 頭檔中定義之NL_SUFFIX_ORIGIN列舉類型的其中一個值。

意義
IpSuffixOriginOther
0
IP 位址後綴是使用這個列舉中所定義來源以外的來源來設定。 此值適用於 IPv6 或 IPv4 位址。
IpSuffixOriginManual
1
IP 位址後綴已手動設定。 此值適用於 IPv6 或 IPv4 位址。
IpSuffixOriginWellKnown
2
IP 位址後綴是使用已知的位址來設定的。 此值適用於 IPv6 連結本機位址或 IPv6 回送位址。
IpSuffixOriginDhcp
3
IP 位址後綴是使用 DHCP 設定的。 此值適用於使用 DHCP 設定的 IPv4 位址,或使用 DHCPv6 設定的 IPv6 位址。
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 位址。 這個成員可以是 Nldef.h 頭檔中定義之NL_DAD_STATE列舉類型的其中一個值。

意義
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 和更新版本上定義。

MIB_UNICASTIPADDRESS_ROW 結構的 SkipAsSource 成員會影響 Windows 套接字中 getaddrinfoGetAddrInfoWGetAddrInfoEx 函式的作業。 如果傳遞至 getaddrinfoGetAddrInfoW 函式的 pNodeName 參數,或傳遞至 GetAddrInfoEx 函式的 pName 參數指向電腦名稱,則會傳回可用來做為來源地址的計算機的所有永久位址。 在 Windows Vista 和更新版本上,這些位址會包含 GetUnicastIpAddressTableGetUnicastIpAddressEntry 函式傳回的所有單播 IP 位址, 其中 SkipAsSource 成員在 MIB_UNICASTIPADDRESS_ROW 結構中設定為 false。

如果 pNodeNamepName 參數參考叢集虛擬伺服器名稱,則只會傳回虛擬伺服器位址。 在 Windows Vista 和更新版本上,這些位址會包含 GetUnicastIpAddressTableGetUnicastIpAddressEntry 函式傳回的所有單播 IP 位址, 其中 SkipAsSource 成員在 MIB_UNICASTIPADDRESS_ROW 結構中設定為 true。 如需叢集的詳細資訊,請參閱 Windows 叢集

Windows 7 Service Pack 1 (SP1) 和 Windows Server 2008 R2 with Service Pack 1 (SP1) 新增支援至 Netsh.exe,以在 IP 位址上設定 SkipAsSource 屬性。 此 Hotfix 也會變更行為,如此一來,如果 MIB_UNICASTIPADDRESS_ROW 結構中的 SkipAsSource 成員設定為 false,IP 位址將會在 DNS 中註冊。 如果 SkipAsSource 成員設定為 true,則不會在 DNS 中註冊 IP 位址。

Hotfix 適用於 Windows 7 和 Windows Server 2008 R2,可新增對 Netsh.exe 的支援,以在 IP 位址上設定 SkipAsSource 屬性。 此 Hotfix 也會變更行為,如此一來,如果 MIB_UNICASTIPADDRESS_ROW 結構中的 SkipAsSource 成員設定為 false,IP 位址將會在 DNS 中註冊。 如果 SkipAsSource 成員設定為 true,則不會在 DNS 中註冊 IP 位址。 如需詳細資訊,請參閱知識庫 (KB ) 2386184

Windows Vista 的 Service Pack 2 (SP2) 和 Windows Server 2008 Service Pack 2 (SP2) 也提供類似的 Hotfix,可新增對 Netsh.exe 的支援,以在 IP 位址上設定 SkipAsSource 屬性。 此 Hotfix 也會變更行為,如此一來,如果 MIB_UNICASTIPADDRESS_ROW 結構中的 SkipAsSource 成員設定為 false,IP 位址將會在 DNS 中註冊。 如果 SkipAsSource 成員設定為 true,則不會在 DNS 中註冊 IP 位址。

範例

下列範例會擷取單播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