前言
题目说的有点长,其实就是以下几件事,第一是让Shell命令可以在程序内执行,然后将执行结果传递给变量,从而可以进行后续的事务处理,第二是使用nmap命令获取当前局域网内所有在线IP和开放的端口,最后就是对nmap获得的结果进行处理,得到只有IP和端口的结果。
Linux命令行的强大功能相信使用Linux的人都知道,一个命令等于你在windows用几百行甚至上千行的代码量才能实现,所以,如果很好的利用shell命令,可以说是事半功倍。
而要充分利用shell的结果,必然是需要获得可以处理的命令返回结果。
程序内执行Shell命令
主要是利用以下的函数:
函数定义:
#include <stdio.h>
FILE * popen(const char *command , const char *type );
int pclose(FILE *stream);
函数说明:
popen()函数通过创建一个管道,调用fork()产生一个子进程,执行一个shell以运行命令来开启一个进程。这个管道必须由pclose()函数关闭,而不是fclose()函数。pclose()函数关闭标准I/O流,等待命令执行结束,然后返回shell的终止状态。如果shell不能被执行,则pclose()返回的终止状态与shell已执行exit一样。

本文介绍了如何在Linux程序内执行Shell命令,特别是利用nmap获取局域网内在线IP和开放端口,并展示了对nmap结果进行处理的方法,以提取IP和端口信息。
&spm=1001.2101.3001.5002&articleId=42967695&d=1&t=3&u=281558445efb455f80f19c0ef540239f)
1767

被折叠的 条评论
为什么被折叠?



