我正在编写一个程序,它可以读取我在特定网络接口(VLAN:eth0.32)上分配的IP地址。我不知道我是否被分配了IPv4或IPv6地址,因此我尝试将其编写为协议族不可知。
它的工作方式是:使用for,我浏览可用网络接口列表,然后停在我找到VLAN(eth0.32)读取IP地址的位置。无论如何,在这个开发阶段,我只是希望它适用于IPv4,但是当我想要实现IPv6支持时,请准备好它。
如果我正常创建套接字,程序将工作并读取IPv4地址:
sd=socket(PF_INET, SOCK_DGRAM, 0);
但由于我无法使用此套接字系列读取IPv6地址(PF_INET = IPv4),我这样做:
sd=socket(PF_INET6, SOCK_DGRAM, 0);
setsockopt(sd, SOL_SOCKET, IPV6_V6ONLY, 0, sizeof(int));
问题是,使用这个IPv6套接字,它无法完成读取ip地址的if条件:
if (ioctl(sd, SIOCGIFCONF, &ifc) == 0)
有关详细信息,请参阅我的全部代码:
#include <stdio.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/ioctl.h>
#include <netinet/in.h>
#include <netdb.h>
#include <net/if.h>
int main(int argc, char **argv)
{
struct ifconf ifc;
struct ifreq ifr[MAX_NETWORK_INTERFACES];
int ifc_num, addr, i;
static uint8 sd=0;
sd=socket(PF_INET6, SOCK_DGRAM, 0);
setsockopt(sd, SOL_SOCKET, IPV6_V6ONLY, 0, sizeof(int)); //I change the socket option IPV6_V6ONLY to false, so it should be compatible with IPv4
if (sd > 0)
{
ifc.ifc_len = sizeof(ifr);
ifc.ifc_ifcu.ifcu_buf = (caddr_t)ifr; //Buffer address
if (ioctl(sd, SIOCGIFCONF, &ifc) == 0)
{
ifc_num = ifc.ifc_len / sizeof(struct ifreq); //Number of network interfaces found
for (i = 0; i < ifc_num; i++)
{
if(ifr[i].ifr_addr.sa_family != AF_INET) //If it is not an IPv4 address, we do nothing
{
continue;
}
if (strcmp(ifr[i].ifr_ifrn.ifrn_name,"eth0.32")==0)
{
if (ioctl(sd, SIOCGIFADDR, &ifr[i]) == 0) // HERE IS WHERE THE IPv6 SOCKET DOESN'T ENTER!!!
{
addr = ntohl(((struct sockaddr_in *)(&ifr[i].ifr_addr))->sin_addr.s_addr);
}
fclose(fp);
break; // end loop
}
}
}
}
return addr;
}
提前感谢您的帮助!
答案 0 :(得分:0)
您应该使用getifaddrs
而不是ioctl SIOCGIFADDR
。