思路:popen打开,命令执行完后,对fp进行读取,读到output参数里面。
注意:size不要太大。一般64,128够用。用1024或者4028,会出现段错误,栈报错。
popen()可以执行shell命令,并读取此命令的返回值;
popen()函数通过创建一个管道,调用fork()产生一个子进程,执行一个shell以运行命令来开启一个进程。可以通过这个管道执行标准输入输出操作。这个管道必须由pclose()函数关闭,而不是fclose()函数(若使用fclose则会产生僵尸进程)。
pclose()函数关闭标准I/O流,等待命令执行结束,然后返回shell的终止状态。
如果shell不能被执行,则pclose()返回的终止状态与shell已执行exit一样。
static int get_system_output(char *cmd, char *output, int size)
{
FILE *fp=NULL;
fp = popen(cmd, "r");
if (fp)
{
if(fgets(output, size, fp) != NULL)
{
if(output[strlen(output)-1] == '\n')
output[strlen(output)-1] = '\0';
}
pclose(fp);
}
return 0;
}
memset( &cmd, 0x00, sizeof(cmd));
snprintf(cmd, sizeof(cmd), "grep \"%s\" %s | cut -d ' ' -f 1", client_mac, net_arp_file);
my_printf(LOG_MODE_LEVEL_1, "[##lin##]%s(%d) cmd:%s\n",__FUNCTION__,__LINE__, cmd);
get_system_output(cmd, client_online_tmp, 64);
my_printf(LOG_MODE_LEVEL_1, "[##lin##]%s(%d) client_online_tmp:%s\n",__FUNCTION__,__LINE__, client_online_tmp);