使用ioctl在Linux中获取IPv6地址

我试图在我的Linux操作系统中获得IPv6地址,如下所示:

sd = Socket_m(AF_INET6_m, SOCK_DGRAM_m, 0); ifc.ifc_buf = buffer_p; ifc.ifc_len = buffSize; Ioctl_m(sd, SIOCGIFCONF, &ifc); 

如果为接口configuration了任何IPv4地址,则它将成功工作,但如果接口只有一个IPv6地址,则不会由ioctl返回。

例如,由于只configuration了IPv6地址,导致无法获得从接口的IPv6地址:

 br1 Link encap:Ethernet HWaddr 00:10:18:2D:BB:34 inet6 addr: fe80::210:18ff:fe2d:be54/64 Scope:Link UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:194244850 errors:0 dropped:0 overruns:0 frame:0 TX packets:72005 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:0 RX bytes:12331900995 (11760.6 Mb) TX bytes:6192406 (5.9 Mb) 

是的,这个ioctl是遗留的,不会返回IPv6。 每个平台都有不同的获取IPv6的方式:

  • Linux,使用NETLINK如果你疯了,使用getifaddrs如果你有一个最近glibc模糊,否则读取/proc/net/if_inet6 (例如在Android上)。
  • 达尔文或FreeBSD:使用getifaddrs
  • Solaris,使用SIOCGLIFCONF
  • AIX,使用实际返回IPv4和IPv6地址的SIOCGIFCONF (因为它们在struct sockaddr有一个sa_len字段,他们实际上可以支持这个字段)。

这可能不会起作用。

man 7 netdevice

SIOCGIFCONF

返回接口(传输层)地址列表。 目前这仅仅意味着AF_INET (IPv4)系列的地址兼容性。

[…]

笔记

[…]

本地IPv6 IP地址可以通过/ proc / net或通过rtnetlink(7)找到。