Estoy usando getifaddrs() y inet_ntop() para obtener las direcciones IP en el sistema. Cuando el sistema está configurado en IPv6, la dirección devuelta se encuentra en la versión abreviada (utilizando :: para ceros). ¿Hay alguna forma de expandir esa dirección a una completa?expandir una dirección IPv6 para que pueda imprimirlo en stdout
Este es el código que estoy utilizando:
struct ifaddrs *myaddrs, *ifa;
void *in_addr;
char buf[64];
if(getifaddrs(&myaddrs) != 0)
{
perror("getifaddrs");
exit(1);
}
for (ifa = myaddrs; ifa != NULL; ifa = ifa->ifa_next)
{
if (ifa->ifa_addr == NULL)
continue;
if (!(ifa->ifa_flags & IFF_UP))
continue;
switch (ifa->ifa_addr->sa_family)
{
case AF_INET:
{
struct sockaddr_in *s4 = (struct sockaddr_in *)ifa->ifa_addr;
in_addr = &s4->sin_addr;
break;
}
case AF_INET6:
{
struct sockaddr_in6 *s6 = (struct sockaddr_in6 *)ifa->ifa_addr;
in_addr = &s6->sin6_addr;
break;
}
default:
continue;
}
if (!inet_ntop(ifa->ifa_addr->sa_family, in_addr, buf, sizeof(buf)))
{
printf("%s: inet_ntop failed!\n", ifa->ifa_name);
}
else
{
printf("IP address: %s\n", buf);
}
}
freeifaddrs(myaddrs);
Código es muy apreciada.
EDIT:
Dado que este es aparentemente muy difícil de comprender le daré un ejemplo:
Si consigo ABCD: 12 :: 3 necesito para expandirlo a ABCD: 0012: 0000: 0000: 0000: 0000: 0000: 0003
¿El motivo? porque es parte de los requisitos. Simple como eso.
la versión abreviada es una dirección IPv6 válida - ¿por qué querrías para expandirlo? – Femaref
porque necesito almacenarlo en su totalidad en nuestra base de datos. ese es el requisito – Jessica
@Jessica: Lo está almacenando como un entero de 128 bits, ¿correcto? Debido a que almacenarlo como una representación textual es un poco inútil, existen direcciones IPv6 que se pueden representar de muchas maneras, precisamente debido a la sintaxis '::' acortada. – Piskvor