在linux上拼ip和端口命令,程序内执行shell命令自动获取局域网内所有在线IP和开放端口(Linux)...

程序内执行shell命令自动获取局域网内所有在线IP和开放端口(Linux)

来源:程序员人生   发布时间:2015-01-24 08:46:11 阅读次数:2644次

前言

题目说的有点长,其实就是以下几件事,第1是让Shell命令可以在程序内履行,然后将履行结果传递给变量,从而可以进行后续的事务处理,第2是使用nmap命令获得当前局域网内所有在线IP和开放的端口,最后就是对nmap取得的结果进行处理,得到只有IP和端口的结果。

Linux命令行的强大功能相信使用Linux的人都知道,1个命令等于你在windows用几百行乃至上千行的代码量才能实现,所以,如果很好的利用shell命令,可以说是事半功倍。

而要充分利用shell的结果,必定是需要取得可以处理的命令返回结果。

程序内履行Shell命令

主要是利用以下的函数:

函数定义:

#include

FILE * popen(const char *command , const char *type );

int pclose(FILE *stream);

函数说明:

popen()函数通过创建1个管道,调用fork()产生1个子进程,履行1个shell以运行命令来开启1个进程。这个管道必须由pclose()函数关闭,而不是fclose()函数。pclose()函数关闭标准I/O流,等待命令履行结束,然后返回shell的终止状态。如果shell不能被履行,则pclose()返回的终止状态与shell已履行exit1样。

type参数只能是读或写中的1种,得到的返回值(标准I/O流)也具有和type相应的只读或只写类型。如果type是"r"则文件指针连接到command的标准输出;如果type是"w"则文件指针连接到command的标准输入。

command参数是1个指向以NULL结束的shell命令字符串的指针。这行命令将被传到bin/sh并使用-c标志,shell将履行这个命令。

popen()的返回值是个标准I/O流,必须由pclose来终止。前面提到这个流是单向的(只能用于读或写)。向这个流写内容相当于写入该命令的标准输入,命令的标准输出和调用popen()的进程相同;与之相反的,从流中读数据相当于读取命令的标准输出,命令的标准输入和调用popen()的进程相同。

返回值:

如果调用fork()或pipe()失败,或不能分配内存将返回NULL,否则返回标准I/O流。popen()没有为内存分配失败设置errno值。如果调用fork()或pipe()时出现毛病,errno被设为相应的毛病类型。如果type参数不合法,errno将返回EINVAL。

使用方法:

//execute shell command

//履行1个shell命令,输出结果逐行存储在resvec中,并返回行数

int32_t myexec(const char *cmd, vector &resvec) {

resvec.clear();

FILE *pp = popen(cmd, "r"); //建立管道

if (!pp) {

return ⑴;

}

char tmp[1024]; //设置1个适合的长度,以存储每行输出

while (fgets(tmp, sizeof(tmp), pp) != NULL) {

if (tmp[strlen(tmp) - 1] == '

') {

tmp[strlen(tmp) - 1] = '

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值