แก้ไข

แชร์ผ่าน


IP Helper overview

Internet Protocol Helper (IP Helper) enables drivers to retrieve information about the local computer's network configuration and to modify that configuration. IP Helper also provides notification mechanisms to make sure that a driver is notified when certain aspects of the local computer network configuration change. IP Helper is available in Windows Vista and later versions of the Microsoft Windows operating systems.

Many of the IP Helper functions pass structure parameters that represent data types that are associated with the Management Information Base (MIB) technology. The IP Helper functions use these MIB structures to represent various networking information.

The IP Helper documentation uses the terms adapter and interface extensively. An adapter is a legacy term that's an abbreviated form of network adapter, which originally referred to some form of network hardware. An adapter is a data link-level abstraction.

An interface is described in the IETF RFC documents as an abstract concept that represents a node's attachment to a link. An interface is an IP-level abstraction.

Your driver can use the following kernel-mode functions, MIB structures, and MIB and network layer (NL) enumerations to retrieve and modify configuration settings for Transmission Control Protocol/Internet Protocol (TCP/IP) transport on a local computer.

Note

When you develop driver code, follow the instructions for including header files.

Interface conversion functions

Function Description
ConvertInterfaceAliasToLuid Converts a locally unique identifier (LUID) for a network interface to the Unicode interface name.
ConvertInterfaceGuidToLuid Converts a globally unique identifier (GUID) for a network interface to the LUID for the interface.
ConvertInterfaceIndexToLuid Converts a local index for a network interface to the LUID for the interface.
ConvertInterfaceLuidToAlias Converts a LUID for a network interface to an interface alias.
ConvertInterfaceLuidToGuid Converts a LUID for a network interface to a GUID for the interface.
ConvertInterfaceLuidToIndex Converts a LUID for a network interface to the local index for the interface.
ConvertInterfaceLuidToNameA Converts a LUID for a network interface to the ANSI interface name.
ConvertInterfaceLuidToNameW Converts a LUID for a network interface to the Unicode interface name.
ConvertInterfaceNameToLuidA Converts an ANSI network interface name to the LUID for the interface.
ConvertInterfaceNameToLuidW Converts a Unicode network interface name to the LUID for the interface.
if_indextoname Converts the local index for a network interface to the ANSI interface name.
if_nametoindex Converts the ANSI interface name for a network interface to the local index for the interface.

Interface management functions

Function Description
GetIfEntry2 Retrieves information for the specified interface on the local computer.
GetIfStackTable Retrieves a table of network interface stack row entries that specify the relationship of the network interfaces on an interface stack.
GetIfTable2 Retrieves the MIB-II interface table.
GetIfTable2Ex Retrieves the MIB-II interface table, given a level of interface information to retrieve.
GetInvertedIfStackTable Retrieves a table of inverted network interface stack row entries that specify the relationship of the network interfaces on an interface stack.
GetIpInterfaceEntry Retrieves IP information for the specified interface on the local computer.
GetIpInterfaceTable Retrieves the IP interface entries on the local computer.
InitializeIpInterfaceEntry Initializes the members of a MIB_IPINTERFACE_ROW structure entry with default values.
SetIpInterfaceEntry Sets the properties of an IP interface on the local computer.

IP address management functions

Function Description
CreateAnycastIpAddressEntry Adds a new anycast IP address entry on the local computer.
CreateSortedAddressPairs Pairs a supplied list of destination addresses together with the host machine's local IP addresses and sorts the pairs according to the preferred order of communication.
CreateUnicastIpAddressEntry Adds a new unicast IP address entry on the local computer.
DeleteAnycastIpAddressEntry Deletes an existing anycast IP address entry from the local computer.
DeleteUnicastIpAddressEntry Deletes an existing unicast IP address entry from the local computer.
GetAnycastIpAddressEntry Retrieves information for an existing anycast IP address entry on the local computer.
GetAnycastIpAddressTable Retrieves the anycast IP address table on the local computer.
GetMulticastIpAddressEntry Retrieves information for an existing multicast IP address entry on the local computer.
GetMulticastIpAddressTable Retrieves the multicast IP address table on the local computer.
GetUnicastIpAddressEntry Retrieves information for an existing unicast IP address entry on the local computer.
GetUnicastIpAddressTable Retrieves the unicast IP address table on the local computer.
InitializeUnicastIpAddressEntry Initializes a MIB_UNICASTIPADDRESS_ROW structure with default values for a unicast IP address entry on the local computer.
NotifyStableUnicastIpAddressTable Retrieves the stable unicast IP address table on a local computer.
SetUnicastIpAddressEntry Sets the properties of an existing unicast IP address entry on the local computer.

IP neighbor address management functions

Function Description
CreateIpNetEntry2 Creates a new neighbor IP address entry on the local computer.
DeleteIpNetEntry2 Deletes a neighbor IP address entry from the local computer.
FlushIpNetTable2 Flushes the IP neighbor table on the local computer.
GetIpNetEntry2 Retrieves information for a neighbor IP address entry on the local computer.
GetIpNetTable2 Retrieves the IP neighbor table on the local computer.
ResolveIpNetEntry2 Resolves the physical address for a neighbor IP address entry on the local computer.
SetIpNetEntry2 Sets the physical address of an existing neighbor IP address entry on the local computer.

IP path management functions

Function Description
FlushIpPathTable Flushes the IP path table on the local computer.
GetIpPathEntry Retrieves information for an IP path entry on the local computer.
GetIpPathTable Retrieves information for an IP path table on the local computer.

IP route management functions

Function Description
CreateIpForwardEntry2 Creates a new IP route entry on the local computer.
DeleteIpForwardEntry2 Deletes an IP route entry from the local computer.
GetBestRoute2 Retrieves the IP route entry on the local computer for the best route to the specified destination IP address.
GetIpForwardEntry2 Retrieves information for an IP route entry on the local computer.
GetIpForwardTable2 Retrieves the IP route entries on the local computer.
InitializeIpForwardEntry Initializes a MIB_IPFORWARD_ROW2 structure with default values for an IP route entry on the local computer.
SetIpForwardEntry2 Sets the properties of an IP route entry on the local computer.

IP table memory management functions

Function Description
FreeMibTable Frees the buffer that is allocated by the functions that return tables of network interfaces, addresses, and routes (for example, GetIfTable2 and GetAnycastIpAddressTable).

Notification functions

Function Description
CancelMibChangeNotify2 Deregisters the driver for change notifications for IP interface changes, IP address changes, IP route changes, and requests to retrieve the stable unicast IP address table.
NotifyIpInterfaceChange Registers the driver to be notified for changes to all IP interfaces, IPv4 interfaces, or IPv6 interfaces on a local computer.
NotifyRouteChange2 Registers to be notified for changes to IP route entries on a local computer.
NotifyUnicastIpAddressChange Registers to be notified for changes to all unicast IP interfaces, unicast IPv4 addresses, or unicast IPv6 addresses on a local computer.

Teredo IPv6 client management functions

Function Description
GetTeredoPort Retrieves the dynamic UDP port number that the Teredo client uses on the local computer.
NotifyTeredoPortChange Registers to be notified for changes to the UDP port number that the Teredo client uses for the Teredo service port on a local computer.
NotifyStableUnicastIpAddressTable Retrieves the stable unicast IP address table on a local computer.

MIB structures

Structure Description
IP_ADDRESS_PREFIX Stores an IP address prefix.
MIB_ANYCASTIPADDRESS_ROW Stores information about an anycast IP address.
MIB_ANYCASTIPADDRESS_TABLE Contains a table of anycast IP address entries.
MIB_IF_ROW2 Stores information about a particular interface.
MIB_IF_TABLE2 Contains a table of logical and physical interface entries.
MIB_IFSTACK_ROW Represents the relationship between two network interfaces.
MIB_IFSTACK_TABLE Contains a table of row entries in the network interface stack. This table specifies the relationship of the network interfaces on an interface stack.
MIB_INVERTEDIFSTACK_ROW Represents the relationship between two network interfaces.
MIB_INVERTEDIFSTACK_TABLE Contains a table of inverted network interface stack row entries. This table specifies the relationship of the network interfaces on an interface stack in reverse order.
MIB_IPFORWARD_ROW2 Stores information about an IP route entry.
MIB_IPFORWARD_TABLE2 Contains a table of IP route entries.
MIB_IPINTERFACE_ROW Stores interface management information for a particular IP address family on a network interface.
MIB_IPINTERFACE_TABLE Contains a table of IP interface entries.
MIB_IPNET_ROW2 Stores information about a neighbor IP address.
MIB_IPNET_TABLE2 Contains a table of neighbor IP address entries.
MIB_IPPATH_ROW Stores information about an IP path entry.
MIB_IPPATH_TABLE Contains a table of IP path entries.
MIB_MULTICASTIPADDRESS_ROW Stores information about a multicast IP address.
MIB_MULTICASTIPADDRESS_TABLE Contains a table of multicast IP address entries.
MIB_UNICASTIPADDRESS_ROW Stores information about a unicast IP address.
MIB_UNICASTIPADDRESS_TABLE Contains a table of unicast IP address entries.

MIB enumerations

Enumeration Description
MIB_IF_TABLE_LEVEL Defines the level of interface information to retrieve.
MIB_NOTIFICATION_TYPE Defines the notification type that is passed to a callback function when a notification occurs.

NL enumerations

Enumeration Description
NL_ADDRESS_TYPE Specifies the IP address type of the network layer.
NL_DAD_STATE Defines the duplicate address detection (DAD) state.
NL_LINK_LOCAL_ADDRESS_BEHAVIOR Defines the link local address behavior.
NL_NEIGHBOR_STATE Defines the state of a network layer neighbor IP address, as described in RFC 2461, section 7.3.2.
NL_PREFIX_ORIGIN Defines the origin of the prefix or network part of the IP address.
NL_ROUTE_ORIGIN Defines the origin of the IP route.
NL_ROUTE_PROTOCOL Defines the routing mechanism that an IP route was added with, as described in RFC 4292.
NL_ROUTER_DISCOVERY_BEHAVIOR Defines the router discovery behavior, as described in RFC 2461.
NL_SUFFIX_ORIGIN Defines the origin of the suffix or host part of the IP address.