Linux 获得机器的IP和网卡信息
Linux 获得机器的IP和网卡信息
代码来自于网络, 我改写了, 有美不敢自专, 特分享之.用法很简单,就3个函数.
头文件getmac.h:
/** * getmac.h * * 2014-07-08: init created */ #ifndef GETMAC_H_INCLUDED #define GETMAC_H_INCLUDED #if defined(__cplusplus) extern "C" { #endif #include <stdio.h> #include <string.h> #include <errno.h> #include <sys/types.h> #include <sys/param.h> #include <sys/ioctl.h> #include <sys/socket.h> #include <net/if.h> #include <netinet/in.h> #include <net/if_arp.h> #include <arpa/inet.h> #include <unistd.h> #ifdef SOLARIS # include <sys/sockio.h> #endif #define GETMAC_MAX_INTERFACES 16 #define GETMAC_MAX_MSGLEN 256 #define GETMAC_NOERROR 0 #define GETMAC_SUCCESS GETMAC_NOERROR #define GETMAC_ERROR (-1) #define GETMAC_EATTR (-2) typedef int GETMAC_BOOL; #define GETMAC_TRUE 1 #define GETMAC_FALSE 0 typedef struct { int fd; struct ifreq buf[GETMAC_MAX_INTERFACES]; struct arpreq arp; int ifaces; } getmac_info_t; typedef struct { int errcode; char errmsg[GETMAC_MAX_MSGLEN]; } getmac_error_t; #define GETMAC_ATTR_IFF_UP 1 /* Interface is up */ #define GETMAC_ATTR_IFF_BROADCAST 2 /* Broadcast address valid */ #define GETMAC_ATTR_IFF_DEBUG 3 /* Turn on debugging */ #define GETMAC_ATTR_IFF_LOOPBACK 4 /* Is a loopback net */ #define GETMAC_ATTR_IFF_POINTOPOINT 5 /* Interface is point-to-point link */ #define GETMAC_ATTR_IFF_NOTRAILERS 6 /* Avoid use of trailers */ #define GETMAC_ATTR_IFF_RUNNING 7 /* Resources allocated */ #define GETMAC_ATTR_IFF_NOARP 8 /* No address resolution protocol */ #define GETMAC_ATTR_IFF_PROMISC 9 /* Receive all packets */ #define GETMAC_ATTR_IFNAME 10 /* Interface name, e.g. "en0". */ #define GETMAC_ATTR_IPADDR 11 /* Address of interface */ #define GETMAC_ATTR_HWADDR 12 /* MAC address */ extern int getmac_init (getmac_info_t * mi, getmac_error_t * err); extern int getmac_attr (getmac_info_t * mi, int i, int attr, void * value, getmac_error_t * err); extern void getmac_fini (getmac_info_t * mi); #if defined(__cplusplus) } #endif #endif /* GETMAC_H_INCLUDED */
C文件getmac.c:
/** * getmac.c * * 2014-07-08: init created */ #include "getmac.h" int getmac_init (getmac_info_t * mi, getmac_error_t * err) { int fd; struct ifconf ifc; bzero (mi, sizeof(getmac_info_t)); mi->fd = -1; fd = socket (AF_INET, SOCK_DGRAM, 0); if (fd == -1) { err->errcode = errno; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "socket() error (%d): %s", strerror(errno)); return GETMAC_ERROR; } /* prepare to get mac numb */ ifc.ifc_len = sizeof(mi->buf); ifc.ifc_buf = (caddr_t) mi->buf; if (ioctl (fd, SIOCGIFCONF, (char *) &ifc)) { err->errcode = errno; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "ioctl() error (%d): %s", strerror(errno)); close (fd); return GETMAC_ERROR; } mi->ifaces = ifc.ifc_len / sizeof (struct ifreq); mi->fd = fd; /* return numb of mac */ return mi->ifaces; } int getmac_attr (getmac_info_t * mi, int i, int attr, void * value, getmac_error_t * err) { if (mi->fd == -1) { snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "getmac_init should be invoked first"); return GETMAC_ERROR; } /* initialize if not a valid name */ if (! mi->buf[i].ifr_name[0]) { if (ioctl (mi->fd, SIOCGIFFLAGS, (char *) & mi->buf[i])) { err->errcode = errno; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "ioctl(SIOCGIFFLAGS) error (%d): %s", strerror(errno)); return GETMAC_ERROR; } if (ioctl (mi->fd, SIOCGIFADDR, (char *) & mi->buf[i])) { err->errcode = errno; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "ioctl(SIOCGIFADDR) error (%d): %s", strerror(errno)); return GETMAC_ERROR; } /* get Hardware Address */ #ifdef SOLARIS do { mi->arp.arp_pa.sa_family = AF_INET; mi->arp.arp_ha.sa_family = AF_INET; ((struct sockaddr_in *) & mi->arp.arp_pa)->sin_addr.s_addr = ((struct sockaddr_in*)(& buf[i].ifr_addr))->sin_addr.s_addr; if ((ioctl (mi->fd, SIOCGARP, (char *) & mi->arp))) { err->errcode = errno; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "ioctl(SIOCGARP) error (%d): %s", strerror(errno)); return GETMAC_ERROR; } } while (0); #else #if 0 do { /* get HW ADDRESS of the net card */ if (ioctl (mi->fd, SIOCGENADDR, (char *) & buf[i])) { err->errcode = errno; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "ioctl(SIOCGENADDR) error (%d): %s", strerror(errno)); return GETMAC_ERROR; } } while (0); #else do { if (ioctl (mi->fd, SIOCGIFHWADDR, (char *) & mi->buf[i])) { err->errcode = errno; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "ioctl(SIOCGIFHWADDR) error (%d): %s", strerror(errno)); return GETMAC_ERROR; } } while (0); #endif #endif } err->errcode = GETMAC_NOERROR; /* get net attribute */ switch (attr) { case GETMAC_ATTR_IFF_UP: /* Interface is up */ if (mi->buf[i].ifr_flags & IFF_UP) { * ((GETMAC_BOOL *) value) = GETMAC_TRUE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Interface is up"); } else { * ((GETMAC_BOOL *) value) = GETMAC_FALSE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Interface is not up"); } break; case GETMAC_ATTR_IFF_BROADCAST: /* Broadcast address valid */ if (mi->buf[i].ifr_flags & IFF_BROADCAST) { * ((GETMAC_BOOL *) value) = GETMAC_TRUE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Broadcast address valid"); } else { * ((GETMAC_BOOL *) value) = GETMAC_FALSE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Broadcast address invalid"); } break; case GETMAC_ATTR_IFF_DEBUG: /* Turn on debugging */ if (mi->buf[i].ifr_flags & IFF_DEBUG) { * ((GETMAC_BOOL *) value) = GETMAC_TRUE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Turn on debugging"); } else { * ((GETMAC_BOOL *) value) = GETMAC_FALSE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Turn off debugging"); } break; case GETMAC_ATTR_IFF_LOOPBACK: /* Is a loopback net */ if (mi->buf[i].ifr_flags & IFF_LOOPBACK) { * ((GETMAC_BOOL *) value) = GETMAC_TRUE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Is a loopback net"); } else { * ((GETMAC_BOOL *) value) = GETMAC_FALSE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Not a loopback net"); } break; case GETMAC_ATTR_IFF_POINTOPOINT: /* Interface is point-to-point link */ if (mi->buf[i].ifr_flags & IFF_POINTOPOINT) { * ((GETMAC_BOOL *) value) = GETMAC_TRUE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Interface is point-to-point link"); } else { * ((GETMAC_BOOL *) value) = GETMAC_FALSE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Interface is not point-to-point link"); } break; case GETMAC_ATTR_IFF_NOTRAILERS: /* Avoid use of trailers */ if (mi->buf[i].ifr_flags & IFF_NOTRAILERS) { * ((GETMAC_BOOL *) value) = GETMAC_TRUE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Avoid use of trailers"); } else { * ((GETMAC_BOOL *) value) = GETMAC_FALSE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Not Avoid use of trailers"); } break; case GETMAC_ATTR_IFF_RUNNING: /* Resources allocated */ if (mi->buf[i].ifr_flags & IFF_RUNNING) { * ((GETMAC_BOOL *) value) = GETMAC_TRUE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Resources allocated"); } else { * ((GETMAC_BOOL *) value) = GETMAC_FALSE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Resources not allocated"); } break; case GETMAC_ATTR_IFF_NOARP: /* No address resolution protocol */ if (mi->buf[i].ifr_flags & IFF_NOARP) { * ((GETMAC_BOOL *) value) = GETMAC_TRUE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "No address resolution protocol"); } else { * ((GETMAC_BOOL *) value) = GETMAC_FALSE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Has address resolution protocol"); } break; case GETMAC_ATTR_IFF_PROMISC: /* Receive all packets */ if (mi->buf[i].ifr_flags & IFF_PROMISC) { * ((GETMAC_BOOL *) value) = GETMAC_TRUE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Receive all packets"); } else { * ((GETMAC_BOOL *) value) = GETMAC_FALSE; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Not a promisc mode"); } break; case GETMAC_ATTR_IFNAME: /* Interface name, e.g. "en0" */ strcpy (value, mi->buf[i].ifr_name); snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Interface name"); break; case GETMAC_ATTR_IPADDR: /* Interface address */ strcpy (value, inet_ntoa (((struct sockaddr_in*) (& mi->buf[i].ifr_addr))->sin_addr)); snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "Interface address"); break; case GETMAC_ATTR_HWADDR: #ifdef SOLARIS do { mi->arp.arp_pa.sa_family = AF_INET; mi->arp.arp_ha.sa_family = AF_INET; ((struct sockaddr_in *) & mi->arp.arp_pa)->sin_addr.s_addr = ((struct sockaddr_in*)(& buf[i].ifr_addr))->sin_addr.s_addr; if ((ioctl (mi->fd, SIOCGARP, (char *) & mi->arp))) { err->errcode = errno; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "ioctl(SIOCGARP) error (%d): %s", strerror(errno)); return GETMAC_ERROR; } else { sprintf (value, "%02x:%02x:%02x:%02x:%02x:%02x", (unsigned char) mi->arp.arp_ha.sa_data[0], (unsigned char) mi->arp.arp_ha.sa_data[1], (unsigned char) mi->arp.arp_ha.sa_data[2], (unsigned char) mi->arp.arp_ha.sa_data[3], (unsigned char) mi->arp.arp_ha.sa_data[4], (unsigned char) mi->arp.arp_ha.sa_data[5] ); } } while (0); #else #if 0 do { sprintf("%02x:%02x:%02x:%02x:%02x:%02x", (unsigned char) mi->buf[i].ifr_enaddr[0], (unsigned char) mi->buf[i].ifr_enaddr[1], (unsigned char) mi->buf[i].ifr_enaddr[2], (unsigned char) mi->buf[i].ifr_enaddr[3], (unsigned char) mi->buf[i].ifr_enaddr[4], (unsigned char) mi->buf[i].ifr_enaddr[5]); } while (0); #else do { sprintf (value, "%02x:%02x:%02x:%02x:%02x:%02x", (unsigned char) mi->buf[i].ifr_hwaddr.sa_data[0], (unsigned char) mi->buf[i].ifr_hwaddr.sa_data[1], (unsigned char) mi->buf[i].ifr_hwaddr.sa_data[2], (unsigned char) mi->buf[i].ifr_hwaddr.sa_data[3], (unsigned char) mi->buf[i].ifr_hwaddr.sa_data[4], (unsigned char) mi->buf[i].ifr_hwaddr.sa_data[5]); } while (0); #endif #endif snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "MAC address"); break; default: err->errcode = GETMAC_EATTR; snprintf (err->errmsg, GETMAC_MAX_MSGLEN, "error attr specified"); return GETMAC_EATTR; } return GETMAC_SUCCESS; } void getmac_fini (getmac_info_t * mi) { if (mi->fd != -1) { close (mi->fd); mi->fd = -1; } }
Linux 获得机器的IP和网卡信息的更多相关文章
- Linux查询一台机器的IP地址和其对应的域名
Linux查询一台机器的IP地址和其对应的域名 youhaidong@youhaidong-ThinkPad-Edge-E545:~$ nslookup > 127.0.0.1 Server: ...
- java获取本机器的IP(linux和windows)
目录 描述 方案描述 获取Windows下的IP 获取linux下的IP 判断操作系统的类型 最后将上面三个方法进行整合 参考 描述 由于项目是部署在集群上的,需要项目能够自动采集各机器的信息.jav ...
- 修改ip 在linux上永久修改IP地址 子网掩码
小结: 1. 子网掩码.子网IP计算 2. linux centos 修改ip地址细节介绍_LINUX_操作系统_脚本之家 http://www.jb51.net/LINUXjishu/66509.h ...
- Linux 单网卡多 IP 的配置方法
Linux 单网卡多 IP 的配置方法 1 .永久配置的方法: 知道在 Linux 下网卡被称为 eth0,eth1,eth2..... ,所有网卡的配置文件都存储在 /etc/sysconfi ...
- Linux 高性能服务器编程——IP协议详解
1 IP服务特点 IP协议是TCP/IP协议族的动力,它为上层协议提供无状态.无连接.不可靠的服务. 无状态:IP通信双方不同步传输数据的状态信息,因此IP数据包的发送.传输和接收都是无序的. ...
- linux操作系统-设置静态ip
在使用linux虚拟机的时候因为经常有关机的需求,然后重新开机后可能面临这上一次获取的ip被改变,在这里我分享一下在linux 下设置静态ip的经验 1.查看路由状态 [root@localhost ...
- VMWare中Linux虚拟机设置静态IP上网的设置方法
VMWare中Linux虚拟机设置静态IP上网的设置方法 标签: vmwareLinux虚拟机securecrt静态IP上网 2016-05-18 02:30 702人阅读 评论(0) 收藏 举报 ...
- linux常用命令:ip 命令
ip命令是Linux下较新的功能强大的网络配置工具. 1.命令格式: ip [OPTIONS] OBJECT [COMMAND [ARGUMENTS]] 2.命令功能: ip命令用来显示或操纵L ...
- linux命令总结之ip命令
Linux的ip命令和ifconfig类似,但前者功能更强大,并旨在取代后者.使用ip命令,只需一个命令,你就能很轻松地执行一些网络管理任务.ifconfig是net-tools中已被废弃使用的一个命 ...
随机推荐
- SceneKit做一个旋转的地球效果
SceneKit可以用寥寥几行帮你完成很多OpenGL复杂的3D设置代码,下面本猫就带大家完成一个旋转的3D地球的场景. 首先需要地球表面图片,将其导入到Xcode中: 我们用SceneKit内置的几 ...
- HDFS的读数据过程分析
我们继续在 FileSystem 类分析,读数据使用的是 open(-)方法,我们可以看到源码 FSDataInputStream in = fileSystem.open(new Path(&quo ...
- Gazebo機器人仿真學習探索筆記(四)模型編輯
模型編輯主要是自定義編輯物體模型構建環境,也可以將多種模型組合爲新模型等,支持外部模型導入, 需要注意的導入模型格式有相應要求,否在無法導入成功, COLLADA (dae), STereoLitho ...
- SQL Server 执行计划操作符详解(2)——串联(Concatenation )
本文接上文:SQL Server 执行计划操作符详解(1)--断言(Assert) 前言: 根据计划,本文开始讲述另外一个操作符串联(Concatenation),读者可以根据这个词(中英文均可)先幻 ...
- dos2unix批量转换的一种方法
Linux本身提供了dos2unix和unix2dos两个命令来实现Windows和Linux文件的转换. 少量文件转换: 对于单个或少量的文件转换,可以直接使用命令,如: dos2unix file ...
- Linux目录架构详解
Linux和Windows操作系统的显著区别之一就是目录架构的不同.Linux操作系统的目录架构遵循文件系统层级结构标准.不知你是否使用ls命令浏览过Linux的根目录"/",亲爱 ...
- shell的追踪与调试选项
选项: -n :不执行shell脚本,只检查语法问题.没有问题则没有输出. -v :执行shell脚本前,现将shell脚本的命令输出到屏幕上.输出一段,执行一段. -x :将使用到的所有shell脚 ...
- Android初级教程XUtils实现“断点续传”下载
对于"断电续传",在任何开发中都显得很重要.xutils对此封装的很好了,可以很简单的实现很多下载功能,其中就包括"断点续传" 主要代码如下: package ...
- React Native之Navigator
移动应用很少只包含一个页面.从你添加第二个页面开始,就得考虑如何管理多个页面间的跳转了. 导航器正是为此而生.它可以管理多个页面间的跳转,也包含了一些常见的过渡动画,包括水平翻页.垂直弹出等等. Na ...
- JSP连接MySQL时老是遇到驱动错误怎么办?
在使用JSP进行web开发的时候总是会不可避免的遇到各种各样的问题.今天我也来讲一讲我遇到的一些奇葩的问题. 驱动出错 一开始我总是以为是我导入到工程的里的jar包的问题,于是我就试验了好几个连接My ...