感谢支持
我们一直在努力

Linux下检测网卡与网线连通状态

   在Linux下使用ifconfigl命令能很方便的查看网卡与网线是否连通,运行ifconfig eth0命令大致输出如下:
# ifconfig eth0
eth0      Link encap:Ethernet  HWaddr 00:25:35:68:CC:D6 
          inet addr:192.168.1.168  Bcast:192.168.1.255  Mask:255.255.255.0
          inet6 addr: fe80::215:c5ff:fe18:ccd6/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:130722 errors:0 dropped:0 overruns:0 frame:0
          TX packets:112560 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:104371099 (99.5 MiB)  TX bytes:20518584 (19.5 MiB)
          Interrupt:16


 
其中的RUNNING就表示网卡与网线正常链接,拔掉网线再运行此命令就会发现RUNNING不在了。


    我的目的是用C语言来实现程序,而Linux系统提供了popen/pclose进程管道让C和shell很方便的交互,不过使用的时候要注意设置权限,以免造成安全隐患。废话不多说,看下面C代码结合shell命令检测网卡与网线连通状况:
netstat.c
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>


/**********************************************************************
* 函数名称: GetNetStat
* 功能描述: 检测网络链接是否断开
* 输入参数:
* 输出参数: 无
* 返 回 值: 正常链接1,断开返回-1
* 其它说明: 本程序需要超级用户权限才能成功调用ifconfig命令
* 修改日期        版本号     修改人          修改内容
* ———————————————————————
* 2010/04/02      V1.0      eden_mgqw
***********************************************************************/
int GetNetStat( )
{
    char    buffer[BUFSIZ];
    FILE    *read_fp;
    int        chars_read;
    int        ret;
   
    memset( buffer, 0, BUFSIZ );
    read_fp = popen(“ifconfig eth0 | grep RUNNING”, “r”);
    if ( read_fp != NULL )
    {
        chars_read = fread(buffer, sizeof(char), BUFSIZ-1, read_fp);
        if (chars_read > 0)
        {
            ret = 1;
        }
        else
        {
            ret = -1;
        }
        pclose(read_fp);
    }
    else
    {
        ret = -1;
    }


    return ret;
}



int main()
{
    int i=0;
    i = GetNetStat();
    printf( “\nNetStat = %d\n”, i );
    return 0;
}


 


下面是编译运行程序的输出结果(正常返回1,断开返回-1):
# cc netstat.c
# ./a.out
NetStat = 1


在此特别感谢linuxeden的shell区版主li-jiahuan帅锅,为本文提供了shell支持-_-!
条条大路通罗马,在CU上有位帅锅用另外一种方法实现了这个功能,内容见下一页

Linux下检测网卡与网线连接状态,使用ioctl向socket发送SIOCETHTOOL命令字。

link_stat.c




#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#include <fcntl.h>
#include <errno.h>
#include <sys/ioctl.h>

#include <sys/types.h>
#include <sys/socket.h>
#include <linux/if.h>
#include <linux/sockios.h>
#include <linux/ethtool.h>

int get_netlink_status(const char *if_name);

int main()
{
    if(getuid() != 0)
    {
        fprintf(stderr, “Netlink Status Check Need Root Power.\n”);
        return 1;
    }
    
    printf(“Net link status: %d\n”, get_netlink_status(“eth0”));

    return 0;
}

// if_name like “ath0”, “eth0”. Notice: call this function
// need root privilege.
// return value:
// -1 — error , details can check errno
// 1 — interface link up
// 0 — interface link down.
int get_netlink_status(const char *if_name)
{
    int skfd;
    struct ifreq ifr;
    struct ethtool_value edata;

    edata.cmd = ETHTOOL_GLINK;
    edata.data = 0;

    memset(&ifr, 0, sizeof(ifr));
    strncpy(ifr.ifr_name, if_name, sizeof(ifr.ifr_name) 1);
    ifr.ifr_data = (char *) &edata;

    if (( skfd = socket( AF_INET, SOCK_DGRAM, 0 )) < 0)
        return 1;

    if(ioctl( skfd, SIOCETHTOOL, &ifr ) == 1)
    {
        close(skfd);
        return 1;
    }

    close(skfd);
    return edata.data;
}

赞(0) 打赏
转载请注明出处:服务器评测 » Linux下检测网卡与网线连通状态
分享到: 更多 (0)

听说打赏我的人,都进福布斯排行榜啦!

支付宝扫一扫打赏

微信扫一扫打赏