En Windows XP (y versiones posteriores) puede utilizar estas funciones:
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include <winsock2.h>
#include <ws2tcpip.h>
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;
}
Enlace con la biblioteca ws2_32.
la función
int inet_pton(int af, const char *src, void *dst);
se declara en el archivo de encabezado:
#include <arpa/inet.h>
si se trata de Windows (Vista o posterior) hay Winsock análogo a esta versión ANSI:
INT WSAAPI InetPton(
_In_ INT Family,
_In_ PCTSTR pszAddrString,
_Out_ PVOID pAddrBuf
);
prueba #include <Ws2tcpip.h>
agregar Ws2_32.lib
Los usuarios de Windows también pueden encontrar la respuesta aquí:
https://docs.microsoft.com/en-us/windows/desktop/api/ws2tcpip/nf-ws2tcpip-inetptonw
El InetPton
La función convierte una dirección de red de Internet IPv4 o IPv6 en su forma de presentación de texto estándar en su forma binaria numérica. La versión ANSI de esta función es inet_pton
.
El InetPton
La función es compatible con Windows Vista y versiones posteriores.
Cuando UNICODE
o _UNICODE
no está definido, InetPton
está definido en InetPtonA
, la versión ANSI de esta función. La versión ANSI de esta función siempre se define como inet_pton
.
Header ws2tcpip.h Library Ws2_32.lib DLL Ws2_32.dll
Necesitas usar el ws2tcpip.h
encabezado y agregue Ws2_32.lib
a su enlazador.
En mi caso, no se pudo encontrar la función, porque había un "#define WINVER 0x0502" en algún lugar de un archivo de encabezado.
En los sistemas Windows, la versión 0x600 (=Vista) es la mínima requerida para esta función.