次の方法で共有


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

IP アドレスのプレフィックスまたはネットワーク部分の発信元。 このメンバーには、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

IP アドレスのサフィックスまたはホスト部分の発信元。 このメンバーには、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 アドレス サフィックスがランダムに生成されました。 この値は、ルーターアドバタイズを受信した後、MAC ハードウェア アドレスからアドレスのホスト部分がランダムに生成された匿名 IPv6 アドレスに適用されます。
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 アドレスのスコープ ID。 このメンバーは、IPv6 アドレスにのみ適用されます。 このメンバーは設定できません。 アドレスが追加されたインターフェイスによって自動的に決定されます。

CreationTimeStamp

種類: LARGE_INTEGER

IP アドレスが作成されたときのタイム スタンプ。

注釈

MIB_UNICASTIPADDRESS_ROW構造は、Windows Vista 以降で定義されています。

MIB_UNICASTIPADDRESS_ROW構造体の SkipAsSource メンバーは、Windows ソケットでの getaddrinfoGetAddrInfoW、および GetAddrInfoEx 関数の操作に影響します。 getaddrinfo 関数または GetAddrInfoW 関数に渡される pNodeName パラメーター、または GetAddrInfoEx 関数に渡される pName パラメーターがコンピューター名をポイントしている場合は、ソース アドレスとして使用できるコンピューターのすべての永続的なアドレスが返されます。 Windows Vista 以降では、これらのアドレスには、MIB_UNICASTIPADDRESS_ROW構造体でSkipAsSource メンバーが false に設定されている GetUnicastIpAddressTable 関数または GetUnicastIpAddressEntry 関数によって返されるすべてのユニキャスト IP アドレスが含まれます。

pNodeName または pName パラメーターがクラスター仮想サーバー名を参照している場合は、仮想サーバー アドレスのみが返されます。 Windows Vista 以降では、これらのアドレスには、MIB_UNICASTIPADDRESS_ROW構造体でSkipAsSource メンバーが true に設定されている GetUnicastIpAddressTable 関数または GetUnicastIpAddressEntry 関数によって返されるすべてのユニキャスト IP アドレスが含まれます。 クラスタリングの詳細については、「 Windows クラスタリング 」を参照してください。

Windows 7 Service Pack 1 (SP1) と Windows Server 2008 R2 Service Pack 1 (SP1) では、IP アドレスに SkipAsSource 属性を設定するためのサポートが Netsh.exe に追加されます。 この修正プログラムは、MIB_UNICASTIPADDRESS_ROW構造体の SkipAsSource メンバーが false に設定されている場合、IP アドレスが DNS に登録されるように動作も変更します。 SkipAsSource メンバーが true に設定されている場合、IP アドレスは DNS に登録されません。

Windows 7 および Windows Server 2008 R2 では、IP アドレスに SkipAsSource 属性を設定するためのサポートを Netsh.exe に追加する修正プログラムを使用できます。 この修正プログラムは、MIB_UNICASTIPADDRESS_ROW構造体の SkipAsSource メンバーが false に設定されている場合、IP アドレスが DNS に登録されるように動作も変更します。 SkipAsSource メンバーが true に設定されている場合、IP アドレスは DNS に登録されません。 詳細については、「ナレッジ ベース (KB) 2386184」を参照してください。

同様の修正プログラムは、Service Pack 2 (SP2) と Windows Server 2008 Service Pack 2 (SP2) を使用する Windows Vista でも使用できます。この修正プログラムは、IP アドレスに SkipAsSource 属性を設定するためのサポートを Netsh.exe に追加します。 この修正プログラムは、MIB_UNICASTIPADDRESS_ROW構造体の SkipAsSource メンバーが 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 [デスクトップ アプリのみ]
Header netioapi.h (Iphlpapi.h を含む)

こちらもご覧ください

CreateUnicastIpAddressEntry

DeleteUnicastIpAddressEntry

GetAddrInfoEx

GetAddrInfoW

GetUnicastIpAddressEntry

GetUnicastIpAddressTable

InitializeUnicastIpAddressEntry

MIB_UNICASTIPADDRESS_TABLE

SOCKADDR_INET

SetUnicastIpAddressEntry

getaddrinfo