在某些应用中需要检测到网卡是否处于link状态,来决定如何处理。查看了下网上已有诸多方式可以实现这些功能,通过调用shell执行来查看网卡的状态是否处于RUNNING状态。可是我试了下此方法并不靠谱。
无论我的RJ45处于link up or link down查看到的状态是RUNNING。
eth1 Link encap:Ethernet HWaddr 00:22:A2:00:10:11
inet addr:192.168.2.1 Bcast:192.168.2.255 Mask:255.255.255.0
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:1415 errors:0 dropped:0 overruns:0 frame:0
TX packets:120 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:100515 (98.1 KiB) TX bytes:9401 (9.1 KiB)
Interrupt:106
无独有偶在一个网页上找到了用c实现的代码,原作者不详,经验证是可以检测网络的端口状态的。
- #include <sys/types.h>
- #include <string.h>
- #include <stdlib.h>
- #include <sys/ioctl.h>
- #include <stdio.h>
- #include <errno.h>
- #include <net/if.h>
-
- struct ethtool_value {
- __uint32_t cmd;
- __uint32_t data;
- };
-
- int main(int argc, char* argv[])
- {
- struct ethtool_value edata;
- int fd = -1, err = 0;
- struct ifreq ifr;
-
- memset(&ifr, 0, sizeof(ifr));
- strcpy(ifr.ifr_name, "eth1");
- fd = socket(AF_INET, SOCK_DGRAM, 0);
- if (fd < 0) {
- perror("Cannot get control socket");
- return 70;
- }
-
- edata.cmd = 0x0000000a;
- ifr.ifr_data = (caddr_t)&edata;
- err = ioctl(fd, 0x8946, &ifr);
- if (err == 0) {
- fprintf(stdout, "Link detected: %s\n",
- edata.data ? "yes":"no");
- } else if (errno != EOPNOTSUPP) {
- perror("Cannot get link status");
- }
- return 0;
- }
阅读(6998) | 评论(0) | 转发(1) |