Android 系统中检测设备的联网状态


前言

在嵌入式Linux开发中,有时候我们程序需要检测设备的联网状态。下面介绍一种通过检测sysfs下的对应文件的方法来检测设备的联网状态。


一、命令行读取

/sys/class 是由kernel在运行时导出的,目的是通过文件系统暴露出硬件的层级关系。
我们可以检测相应的文件来实时得得到网络连接的状态。

检测无线网络的连接状态,可检测文件:

/sys/class/net/wlan0/operstate

在这里插入图片描述

检测有线网络的连接状态,可检测文件:

/sys/class/net/eth0/operstate

在这里插入图片描述
通过命令行读取,返回down则表明设备网络已断开,返回up则表明设备网络已连接。

二、应用程序测试

测试代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>    
#include <sys/socket.h>       // bind
#include <sys/ioctl.h>
#include <linux/if_packet.h>  
#include <netinet/in.h>      // struct sockaddr_in
#include <netinet/in.h>      // for function htons

typedef enum _net_conn_status
{
    
    
    NET_DISCONNECT = -1,
    NET_CONNECT = 1
}net_conn_status_e;

static int check_net_status(void)
{
    
    
    int ret = 0;

    static char cmd_out[128] = {
    
    0};
    FILE *fp = popen("cat /sys/class/net/wlan0/operstate", "r");
    if(fp == NULL)
    {
    
    
        printf("popen error\n");
        return -1;
    }

    bzero(cmd_out, sizeof(cmd_out));
    fscanf(fp, "%s", cmd_out);
    pclose(fp);
    // printf("cmd_out = %s\n", cmd_out);
    if (0 == strcmp((char*)cmd_out, "down"))
    {
    
    
        // printf("net disconnect\n");
        return -1;
    }
    else if (0 == strcmp((char*)cmd_out, "up"))
    {
    
    
        // printf("net connect\n");
        return 1;
    }else{
    
    }

    return ret;
}

int main(int argc, char **argv)
{
    
    
    while (1)
    {
    
    
        if (NET_DISCONNECT == check_net_status())
        {
    
    
            printf("net disconnect====================\n");
        }
        else if (NET_CONNECT == check_net_status())
        {
    
    
            printf("net connect====================\n");
        }
        usleep(10 * 1000);
    }

    return 0;
}

Makefile:

CROSS_COMPILE = sdk/prebuilts/gcc/linux-x86/aarch64/gcc-linaro-6.3.1-2017.05-x86_64_aarch64-linux-gnu/bin/aarch64-linux-gnu-
CC            = ${
    
    CROSS_COMPILE}gcc
AR            = ${
    
    CROSS_COMPILE}ar
ARFLAGS       = rcs
TARGET        := app

SOURCES       = $(wildcard $(TARGET).c)
OBJS          = $(patsubst %.c, %.o, $(SOURCES))

all:${
    
    TARGET}

#execute bin in elf
${
    
    TARGET}:$(OBJS)
	@mkdir -p build
	$(CC) $(OBJS) -o build/$(TARGET) -static

#compile
%.o:%.c
	$(CC) $(INCLUDE) $(DEBUGS) ${
    
    CFLAGS} -c $< -o $@

.PHONY:clean
clean:
	 @echo "remove app and objs files ..."
	 rm -rf $(OBJS) $(target) build *.o


编译后将生成的应用程序app push 到安卓设备中。
在这里插入图片描述
测试:
在这里插入图片描述

这种方法可以比较实时地检测到网络状态的变化。


猜你喜欢

转载自blog.csdn.net/chenkanuo/article/details/134379510