inet_pton 函数 (ws2tcpip.h)

InetPton 函数将其标准文本表示形式中的 IPv4 或 IPv6 Internet 网络地址转换为数字二进制形式。 此函数的 ANSI 版本 inet_pton

语法

INT WSAAPI inet_pton(
  [in]  INT   Family,
  [in]  PCSTR pszAddrString,
  [out] PVOID pAddrBuf
);

参数

[in] Family

地址系列。

地址系列的可能值在 Ws2def.h 头文件中定义。 请注意, Ws2def.h 头文件会自动包含在 Winsock2.h 中,永远不应直接使用。 请注意,AF_地址系列和PF_协议系列常量的值 (相同,例如 ,AF_INETPF_INET) ,因此可以使用任一常量。

当前支持的值 AF_INETAF_INET6

含义
AF_INET
2
Internet 协议版本 4 (IPv4) 地址系列。 指定此参数时, pszAddrString 参数必须指向 IPv4 地址的文本表示形式, pAddrBuf 参数返回指向表示 IPv4 地址 的IN_ADDR 结构的指针。
AF_INET6
23
Internet 协议版本 6 (IPv6) 地址系列。 指定此参数时, pszAddrString 参数必须指向 IPv6 地址的文本表示形式, pAddrBuf 参数返回指向表示 IPv6 地址 的IN6_ADDR 结构的指针。

[in] pszAddrString

指向 以 NULL 结尾的字符串的指针,该字符串包含要转换为数字二进制形式的 IP 地址的文本表示形式。

Family 参数 AF_INET时, pszAddrString 参数必须以标准点十进制表示法指向 IPv4 地址的文本表示形式。

Family 参数 AF_INET6时, pszAddrString 参数必须以标准表示法指向 IPv6 地址的文本表示形式。

[out] pAddrBuf

指向存储 IP 地址的数字二进制表示形式的缓冲区的指针。 IP 地址按网络字节顺序返回。

AF_INETFamily 参数时,此缓冲区的大小应足以容纳IN_ADDR结构。

AF_INET6Family 参数时,此缓冲区的大小应足以容纳IN6_ADDR结构。

返回值

如果未发生错误, InetPton 函数将返回值 1, 并且 pAddrBuf 参数指向的缓冲区包含网络字节顺序中的二进制数字 IP 地址。

如果 pAddrBuf 参数指向的字符串不是有效的 IPv4 点十进制字符串或有效的 IPv6 地址字符串,则 InetPton 函数将返回值 0。 否则,将返回值 -1,并且可以通过调用 来检索特定的错误代码
用于扩展错误信息的 WSAGetLastError

如果函数有错误, 则 WSAGetLastError 返回的扩展错误代码可以是以下值之一。

错误代码 含义
WSAEAFNOSUPPORT
不支持 Family 参数中指定的 地址系列。 如果指定的 Family 参数未 AF_INETAF_INET6,则返回此错误。
WSAEFAULT
pszAddrStringpAddrBuf 参数为 NULL,或者不是用户地址空间的一部分。

注解

Windows Vista 及更高版本支持 InetPton 函数。

InetPton 函数提供以标准文本表示形式将 Internet 网络地址转换为数字二进制形式的与协议无关的转换。 InetPton 函数采用 pszAddrString 参数指向的 Internet 地址的文本表示形式,并返回指向 pAddrBuf 参数中数字二进制 IP 地址的指针。 虽然 inet_addr 函数仅适用于 IPv4 地址字符串, 但 InetPton 函数适用于 IPv4 或 IPv6 地址字符串。

此函数的 ANSI 版本 inet_pton RFC 2553 中定义。 有关详细信息,请参阅 IETF 网站上提供的 RFC 2553。

InetPton 函数不要求加载 Windows 套接字 DLL 以执行将表示 IP 地址的文本字符串转换为数字二进制 IP 地址。

如果指定的 Family 参数 为 AF_INET,则 pszAddrString 参数必须以点十进制表示法指向 IPv4 地址的文本字符串,如“192.168.16.0”(点十进制表示法中的 IPv4 地址的示例)。

如果指定的 Family 参数 AF_INET6,则 pszAddrString 参数必须以 Internet 标准格式指向 IPv6 地址的文本字符串。 基本字符串表示形式由 8 个用冒号分隔的十六进制数组成。 连续零数字的字符串可以替换为双冒号。 IPv6 地址的字符串表示形式中只能有一个双冒号。 如果地址是 IPv4 兼容地址,则最后 32 位可能以 IPv4 样式的点八位表示法表示。

定义 UNICODE 或 _UNICODE 时, 将 InetPton 定义为此函数的 Unicode 版本 InetPtonWpszAddrString 参数定义为 PCWSTR 数据类型。

如果未定义 UNICODE 或 _UNICODE, 则会将 InetPton 定义为 InetPtonA,即此函数的 ANSI 版本。 此函数的 ANSI 版本始终定义为inet_pton。 pszAddrString 参数定义为 PCSTR 数据类型。

IN_ADDR结构在 Inaddr.h 头文件中定义。

IN6_ADDR 结构在 In6addr.h 头文件中定义。

在 Windows Vista 及更高版本上, RtlIpv4StringToAddressRtlIpv4StringToAddressEx 函数可用于将 Internet 标准点十进制表示法中的 IPv4 地址的文本表示形式转换为表示为 IN_ADDR 结构的数字二进制地址。 在 Windows Vista 及更高版本中, RtlIpv6StringToAddressRtlIpv6StringToAddressEx 函数可用于将 IPv6 地址的字符串表示形式转换为表示为 IN6_ADDR 结构的数值二进制 IPv6 地址。 RtlIpv6StringToAddressEx 函数更灵活,因为它还可以将 IPv6 地址的字符串表示形式(可在标准表示法中包括范围 ID 和端口)转换为数字二进制形式。

Windows 8.1Windows Server 2012 R2:Windows 8.1、Windows Server 2012 R2 及更高版本的 Windows 应用商店应用支持 InetPtonW 函数。

要求

要求
最低受支持的客户端 Windows 8.1,Windows Vista [桌面应用 |UWP 应用]
最低受支持的服务器 Windows Server 2008 [桌面应用 | UWP 应用]
目标平台 Windows
标头 ws2tcpip.h
Library Ws2_32.lib
DLL Ws2_32.dll

另请参阅

IN6_ADDR

IN_ADDR

InetNtop

RtlIpv4AddressToString

RtlIpv4AddressToStringEx

RtlIpv4StringToAddress

RtlIpv4StringToAddressEx

RtlIpv6AddressToString

RtlIpv6AddressToStringEx

RtlIpv6StringToAddress

RtlIpv6StringToAddressEx

inet_addr

inet_ntoa