Używam getifaddrs() i inet_ntop(), aby uzyskać adresy IP w systemie. Gdy system jest ustawiony na IPv6, zwracany adres jest w skróconej wersji (używając :: dla zer). Czy istnieje sposób na rozszerzenie tego adresu na pełny?rozwiń adres IPv6, dzięki czemu mogę go wydrukować na stdout
Jest to kod używam:
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);
Code jest mile widziana.
EDIT:
Ponieważ jest to podobno bardzo trudno pojąć, dam ci przykład:
Jeśli dostanę abcd: 12 :: 3 muszę go rozwinąć do abcd: 0012: 0000: 0000: 0000: 0000: 0000: 0003
Powód? ponieważ jest to część wymagań. Proste.
wersja skrócona jest prawidłowy adres IPv6 - więc dlaczego nie chcesz, aby ją rozwinąć? – Femaref
, ponieważ muszę przechowywać go w całości w naszej bazie danych. to jest wymaganie. – Jessica
@Jessica: Przechowujesz go jako 128-bitową liczbę całkowitą, prawda? Ponieważ przechowywanie go jako reprezentacji tekstowej jest nieco bezcelowe - istnieją adresy IPv6, które można reprezentować na wiele sposobów, właśnie ze względu na skróconą składnię '::'. – Piskvor