什么是Windows XP等效的inet_pton或InetPton?

我需要确定特定字符串是否是有效的IPv4或IPv6地址文字。 如果我理解正确,在POSIX系统上执行此操作的正确方法是使用inet_pton将其转换为网络地址结构并查看是否成功。 Windows Vista和更高版本的InetPton基本上都是一样的。 但据我所知,Windows XP并未声明其中任何一种,我需要能够在XP上正确执行此操作。 那么,问题是使用什么系统function来做到这一点?

最糟糕的情况是,我可以编写一个函数来自己解析它,但我更喜欢一个标准的系统函数,因此经过全面测试并正确处理所有角落情况等等。 已经糟糕的是,微软不能像其他人一样宣布inet_ptonInetPton来推出更新的操作系统。

在Windows XP中,您可以使用以下function:

 #include  #include  #include  #include  #include  int inet_pton(int af, const char *src, void *dst) { struct sockaddr_storage ss; int size = sizeof(ss); char src_copy[INET6_ADDRSTRLEN+1]; ZeroMemory(&ss, sizeof(ss)); /* stupid non-const API */ strncpy (src_copy, src, INET6_ADDRSTRLEN+1); src_copy[INET6_ADDRSTRLEN] = 0; if (WSAStringToAddress(src_copy, af, NULL, (struct sockaddr *)&ss, &size) == 0) { switch(af) { case AF_INET: *(struct in_addr *)dst = ((struct sockaddr_in *)&ss)->sin_addr; return 1; case AF_INET6: *(struct in6_addr *)dst = ((struct sockaddr_in6 *)&ss)->sin6_addr; return 1; } } return 0; } const char *inet_ntop(int af, const void *src, char *dst, socklen_t size) { struct sockaddr_storage ss; unsigned long s = size; ZeroMemory(&ss, sizeof(ss)); ss.ss_family = af; switch(af) { case AF_INET: ((struct sockaddr_in *)&ss)->sin_addr = *(struct in_addr *)src; break; case AF_INET6: ((struct sockaddr_in6 *)&ss)->sin6_addr = *(struct in6_addr *)src; break; default: return NULL; } /* cannot direclty use &size because of strict aliasing rules */ return (WSAAddressToString((struct sockaddr *)&ss, sizeof(ss), NULL, dst, &s) == 0)? dst : NULL; } 

而已。 链接ws2_32库。

但据我所知,Windows XP并未声明其中任何一种,我需要能够在XP上正确执行此操作。

InetPton文档说明了以下要求:

  • 支持的最低客户端: Windows Vista [仅限桌面应用程序]
  • 支持的最低服务器: Windows Server 2008 [仅限桌面应用程序]

最糟糕的情况是,我可以编写一个函数来自己解析它,但我更喜欢一个标准的系统函数,因此经过全面测试并正确处理所有角落情况等等。

如何依赖来自OSS网络工具Wireshark的一部分代码?

您可以在源代码存储库中找到inet_pton的重新实现。

许可证(见下文)是非常宽松的,所以这可能是一个很好的选择。

如果上述版权声明和本许可声明出现在所有副本中,则允许出于任何目的使用,复制,修改和分发此软件,无论是否收费。

查看SDK头文件,我发现在“c:\ Program Files \ Microsoft SDKs \ Windows \ v7.1 \ Include \ WS2tcpip.h”中声明了inet_pton()InetPton只是#define。

所以,似乎MS毕竟提供了适当的界面,但只是从Vista开始。 但是,如果我没记错的话,XP没有值得一提的IPv6支持。

另一种选择是通过两次调用WSAAddressToString()来自己包装,一次使用AF_INET ,一次使用AF_INET6 。 我在这里猜测文档,没试过。