linux的c方式获取shell结果

本文介绍了一种在C语言中使用popen函数执行外部命令的方法,并提供了两个示例:一个是使用malloc分配内存,另一个是避免使用malloc以防止内存检测工具误报。通过这两个示例,读者可以了解到如何在C程序中安全地执行外部命令并获取其输出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用popen

test.c

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

int cmd_run(char *cmd, char* results, int len)
{
        FILE *fp;
        char *buf;
        int totolen = 0;

        printf("run_cmd: [%s]\n", cmd);
        if ((fp = popen(cmd, "r")) == NULL) {
                printf("NMPPROTDATA_LOG: Fail to popen %s\n", cmd);
                return -1;
        }
        buf = (char *)calloc(1, len);
        if (buf == NULL)
        {
                pclose(fp);
                printf("NMPPROTDATA_LOG: Fail to alloc buffer %d\n", len);
                return -1;
        }
        while (fgets(buf, (len - totolen), fp) != NULL) {
                strcpy(results + totolen, buf);
                totolen += strlen(buf);
                if(len == (totolen + 1)) {
                    //read enough string
                    break;
                }
                memset(buf, 0, len);
        }

        pclose(fp);
        free(buf);
        //printf("results: [%s]\n", results);

        return 0;
}



int main(void) {
	int ret_val = -1;
	char buf[20] = {0};
	char cmd[512] = {0};
	printf("start\n");
	
	
	sprintf(cmd, "pwd");
	ret_val = cmd_run(cmd, buf, sizeof(buf));
	if(ret_val < 0) {
		printf("execute fail\n");
	} else {
		printf("result:%s\n", buf);	
	}
}

不用malloc方式,避免用内存检测工具误报

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
 
int cmd_run(char *cmd, char* results, int len)
{
        FILE *fp;
        char buf[len];
        int totolen = 0;
 
        printf("run_cmd: [%s]\n", cmd);
        if ((fp = popen(cmd, "r")) == NULL) {
                printf("NMPPROTDATA_LOG: Fail to popen %s\n", cmd);
                return -1;
        }
			  memset(buf, 0, len);
        while (fgets(buf, (len - totolen), fp) != NULL) {
                strcpy(results + totolen, buf);
                totolen += strlen(buf);
                if(len == (totolen + 1)) {
                    //read enough string
                    break;
                }
                memset(buf, 0, len);
        }
 
        pclose(fp);
        //printf("results: [%s]\n", results);
 
        return 0;
}
 
 
 
int main(void) {
	int ret_val = -1;
	char buf[3] = {0};
	char cmd[512] = {0};
	printf("start\n");
	
	
	sprintf(cmd, "ls");
	ret_val = cmd_run(cmd, buf, sizeof(buf));
	if(ret_val < 0) {
		printf("execute fail\n");
	} else {
		printf("result:%s\n", buf);	
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值