linux 系统获取网络ip, mask, gateway, dns信息小程序
net_util.c
#define WIRED_DEV "eth0"
#define WIRELESS_DEV "ra0"
#define PPPOE_DEV "ppp0"
#define DEBUG_PRT(fmt, arg...) printf(fmt,##arg)
/**
* get ip address.
* @param net_dev net device.
* @param ipaddr a pointer to save ip address.
* @return 0 success, or fail.
*/
int get_ipaddr(const char *net_dev, char *ipaddr)
{
struct ifreq ifr;
int fd = 0;
struct sockaddr_in *pAddr;
if((NULL == net_dev) || (NULL == ipaddr))
{
DEBUG_PRT("illegal call function SetGeneralIP! \n");
return -1;
}
if((fd = socket(AF_INET,SOCK_DGRAM,0)) < 0)
{
DEBUG_PRT("open socket failed \n");
return -1;
}
memset(&ifr,0,sizeof(ifr));
strcpy(ifr.ifr_name, net_dev);
if(ioctl(fd, SIOCGIFADDR, &ifr) < 0)
{
DEBUG_PRT("SIOCGIFADDR socket failed \n");
close(fd);
return -1;
}
pAddr = (struct sockaddr_in *)&(ifr.ifr_addr);
strcpy(ipaddr, inet_ntoa(pAddr->sin_addr));
close(fd);
return 0;
}
/**
* get gateway.
* @param gateway a pointer to save geteway.
* @return none.
*/
void get_gateway(ITI_CHAR *gateway)
{
char buf[1024]={0};
char *p = NULL;
char *q = NULL;
int count = 0;
if(NULL == gateway)
{
DEBUG_PRT("gateway is NULL \n");
return;
}
cmd_run("route | grep default", buf, 1024);
if(0 == strlen(buf))
{
DEBUG_PRT("get gateway error \n");
return;
}
p = strstr2(buf, "default");
q = p;
while(*q == ' ')
{
q++;
}
p = q;
while(*p != ' ')
{
p++;
count++;
}
if(NULL != q)
{
memcpy(gateway, q, count);
}
gateway[count] = '\0';
}
/**
* get mask.
* @param net_dev net device.
* @param mask a pointer to save mask.
* @return none.
*/
void get_mask(const char *net_dev, ITI_CHAR *mask)
{
char buf[1024]={0};
char *p = NULL;
if(NULL == mask)
{
DEBUG_PRT("mask is NULL \n");
return;
}
if(0 == (memcmp(WIRED_DEV, net_dev, sizeof(WIRED_DEV))))
{
cmd_run("ifconfig eth0 | grep Mask", buf, 1024);
}
else if(0 == (memcmp(WIRELESS_DEV, net_dev, sizeof(WIRELESS_DEV))))
{
cmd_run("ifconfig ra0 | grep Mask", buf, 1024);
}
else if(0 == (memcmp(PPPOE_DEV, net_dev, sizeof(PPPOE_DEV))))
{
cmd_run("ifconfig ppp0 | grep Mask", buf, 1024);
}
else
{
DEBUG_PRT("net device not support \n");
return;
}
if(0 == strlen(buf))
{
DEBUG_PRT("get mask error \n");
return;
}
p = strstr2(buf, "Mask:");
if(NULL == p)
{
DEBUG_PRT("get mask error \n");
return;
}
strcpy(mask, p);
}
/**
* get dns.
* @param dns1 a pointer to save first dns.
* @param dns2 a pointer to save second dns.
* @return 0 success, or fail.
*/
int get_dns(char *dns1, char *dns2)
{
int fd = -1;
int size = 0;
char strBuf[100];
char tmpBuf[100];
int buf_size = sizeof(strBuf);
char *p = NULL;
char *q = NULL;
int i = 0;
int j = 0;
int count = 0;
fd = open("/etc/resolv.conf", O_RDONLY);
if(-1 == fd)
{
DEBUG_PRT("%s open error \n", __func__);
return -1;
}
size = read(fd, strBuf, buf_size);
if(size < 0)
{
DEBUG_PRT("%s read file len error \n", __func__);
close(fd);
return -1;
}
strBuf[buf_size] = '\0';
close(fd);
while(i < buf_size)
{
if((p = strstr2(&strBuf[i], "nameserver")) != NULL)
{
j++;
p += 1;
count = 0;
memset(tmpBuf, 0xff, 100);
memcpy(tmpBuf, p, 100);
tmpBuf[sizeof(tmpBuf) -1 ] = '\0';
q = p;
while(*q != '\n')
{
q++;
count++;
}
i += (sizeof("nameserver") + count);
if(1 == j)
{
memcpy(dns1, p, count);
dns1[count]='\0';
}
else if(2 == j)
{
memcpy(dns2, p, count);
dns2[count]='\0';
}
}
else
{
i++;
}
}
return 0;
}
main.c
void main(void)
{
#define WIRED_DEV "eth0"
#define WIRELESS_DEV "ra0"
#define PPPOE_DEV "ppp0"
char buf[1024] = {'\0'};
extern int get_ipaddr(const char *net_dev, char *ipaddr);
get_ipaddr(WIRED_DEV, buf);
printf("get_ipaddr: %s \n", buf);
memset(buf, '\0', sizeof(buf));
extern void get_mask(const char *net_dev, ITI_CHAR *mask);
get_mask(WIRED_DEV, buf);
printf("get_mask: %s \n", buf);
memset(buf, '\0', sizeof(buf));
extern void get_gateway(ITI_CHAR *gateway);
get_gateway(buf);
printf("get_gateway: %s \n", buf);
memset(buf, '\0', sizeof(buf));
extern int get_dns(char *dns1, char *dns2);
get_dns(buf, &buf[100]);
printf("get_dns: %s %s\n", buf, &buf[100]);
memset(buf, '\0', sizeof(buf));
}
makefile:
gcc main.c net_util.c -o get_net_info
./get_net_info
运行结果:
get_ipaddr: 192.168.9.142
get_mask: 255.255.255.0
get_gateway: 192.168.9.254
get_dns: 192.168.9.11 192.168.9.10
为提高执行效率, 更新获取网关和子网掩码程序:
static void get_gateway(const char *net_dev, char *gateway)
{
FILE *fp;
char buf[1024];
char iface[16];
unsigned char tmp[100]={'\0'};
unsigned int dest_addr=0, gate_addr=0;
if(NULL == gateway)
{
DEBUG_PRT("gateway is NULL \n");
return;
}
fp = fopen("/proc/net/route", "r");
if(fp == NULL){
DEBUG_PRT("fopen error \n");
return;
}
fgets(buf, sizeof(buf), fp);
while(fgets(buf, sizeof(buf), fp))
{
if((sscanf(buf, "%s\t%X\t%X", iface, &dest_addr, &gate_addr) == 3)
&& (memcmp(net_dev, iface, strlen(net_dev)) == 0)
&& gate_addr != 0)
{
memcpy(tmp, (unsigned char *)&gate_addr, 4);
sprintf(gateway, "%d.%d.%d.%d", (unsigned char)*tmp, (unsigned char)*(tmp+1), (unsigned char)*(tmp+2), (unsigned char)*(tmp+3));
break;
}
}
fclose(fp);
}
static void get_mask(const char *net_dev, ITI_CHAR *mask)
{
struct sockaddr_in *pAddr;
struct ifreq ifr;
int sockfd;
sockfd = socket(AF_INET,SOCK_DGRAM,0);
memset(&ifr,0,sizeof(ifr));
strcpy(ifr.ifr_name, net_dev);
if(ioctl(sockfd, SIOCGIFNETMASK, &ifr) < 0){
DEBUG_PRT("SIOCGIFADDR socket failed \n");
close(sockfd);
return ;
}
pAddr = (struct sockaddr_in *)&(ifr.ifr_addr);
strcpy(mask, (char *)(inet_ntoa(pAddr->sin_addr)));
close(sockfd);
}
linux 系统获取网络ip, mask, gateway, dns信息小程序的更多相关文章
- 如何配置Linux系统的网络IP地址
一台安装了Linux系统的电脑如果想要联网,首先要做的就是进行网络配置.今天小编就以CentOS6.4系统为例为大家介绍整个网络配置的过程,虽然只是以CentOS6.4系统为例,但是其它的Linux系 ...
- (转)Linux系统基础网络配置老鸟精华篇
Linux系统基础网络配置老鸟精华篇 原文:http://blog.51cto.com/oldboy/784625 对于linux高手看似简单的网络配置问题,也许要说出所以然来也并不轻松,因此仍然有太 ...
- CentOS(六)--Linux系统的网络环境配置
Linux系统下的网络环境配置,Linux.Unix就是网络的世界,所以在Linux系统中如何配置网络环境变量是至关重要的,这里将会给出3种Linux系统下网络环境配置的方法! 在配置网络环境之前,首 ...
- Linux 系统的网络基础_【all】
网络基础 1.网线:568B: 白橙 橙色 白绿 蓝色 白蓝 绿色 白棕 棕色 2.交换机:电信号转发的网络设备,它可以为接入交换机的任2个网络节点设备提供电信号通信 3.路由器:连接局域网,广域网的 ...
- Linux系统基本网络配置之ifconfig命令
Linux系统基本网络配置之ifconfig命令 一.Linux系统的网络配置基本包括:网络IP的配置.网关路由的配置.主机DNS的配置.主机名的配置等,本篇注重介绍网络IP的配置. 二.Linux系 ...
- Linux系统之网络相关的命令
Linux系统之网络相关的命令 网络概述 网络:通过通信介质和通信设备 将分布不同地点的两台或多台计算机,经过相应的程序实现通信switch 交换机router 路由器网络的功能:数据通信:利用网络传 ...
- 获得Unix/Linux系统中的IP、MAC地址等信息
获得Unix/Linux系统中的IP.MAC地址等信息 中高级 | 2010-07-13 16:03 | 分类:①C语言. Unix/Linux. 网络编程 ②手册 | 4,471 次阅读 ...
- Linux系统NFS网络文件系统
Linux系统NFS网络文件系统 NFS(network file system)网络文件系统,就是通过网络让不同的主机系统之间可以共享文件或目录,此种方法NFS客户端使用挂载的方式让共享文件或目录到 ...
- Linux如何配置网络ip?
Linux如何配置网络ip? 1.首先切换至root用户 su root 输入root用户密码 2.借助dhclient工具自动生成一个网络内可用的ip地址 我们可以手动配置对应的网段的ip地址,但是 ...
随机推荐
- thinkphp autoload 命名空间自定义 namespace
使用thinkPHP过程中,一些自定义的类库和第三方类库需要找一个合适的位置放置,放到系统默认的org文件夹感觉不太好,破坏了thinkPHP的原生目录. 就看了一下官方手册,可以在模块或者应用的配置 ...
- 存储过程/游标/mysql 函数
存储过程和函数(存储在 mysql数据库中的 proc表,所以检查有没有这个表)存储过程是一种存储程序(如正规语言里的子程序一样),mysql支持有两种:存储过程,在其他SQL语句中可以返回值的函数( ...
- 修改VC++2010界面左上角图标
(1)在Resource View中创建或者插入一个新的Icon资源,用于你想要的程序图标,假设ID号为IDI_ICON(这种图标要有16*16和32*32两种格式的,前者用于最小化和列表显示等,后者 ...
- mysql Error Handling and Raising in Stored Procedures
MySQL的存储过程错误捕获方式和Oracle的有很大的不同. MySQL中可以使用DECLARE关键字来定义处理程序.其基本语法如下: DECLARE handler_type HANDLER FO ...
- easy-ui datagrid
Easy-ui引用 <link href="css/EasyUI/themes/icon.css" rel="stylesheet" type=&q ...
- c++ union学习
看到公司前辈的代码中用到了union,不管是大学还是工作用到union机会比较少,还是挺新奇的.所以特意找些资料学习学习 前辈的代码: #include<iostream> using n ...
- C语言字符知识狭区
C语言字符在用户接口软件编程上经常用到,但是有一些狭区会让编程出现一些小BUG,现在总结与此. 1.'\\' 代表的是字符\,而'\'是不能代表字符\的.通常\后面都要跟上数字或者其他字母来表示一个特 ...
- BZOJ 1507 [NOI2003]Editor
Description Input 输 入文件editor.in的第一行是指令条数t,以下是需要执行的t个操作.其中: 为了使输入文件便于阅读,Insert操作的字符串中可能会插入一些回车符,请忽略掉 ...
- entity framework in mysql
To start using Entity Framework 6 and Visual Studio 2013 is necessary to install MySQL for Visual St ...
- VSCode调试go
VSCode调试go语言出现:exec: "gcc": executable file not found in %PATH% 1.问题描述 由于安装VS15 Preview ...