我要做的是每10秒记录一次airodump ng的输出。
第一次尝试:通过airodump-ng 文档当我尝试使用它时,他们提到了这样一个命令--write-interval:sudo airodump-ng mon0 -w testOutput --write-interval 10 -o csv,我得到了一个错误,即--write-interval是一个无法识别的选项。
第二次尝试:--我尝试用Python自己做这件事。然后我意识到了试图停止这一进程的问题。离我最近的是这个解决方案。
airodump = subprocess.Popen(['sudo', 'airodump-ng', 'mon0', '-w', 'pythonTest'],
stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
o_airodump, unused_stderr = airodump.communicate(timeout=15)
airodump.kill()这确实停止了这个过程,而且我确实有相关的输出文件,但是所发生的情况是,我所有的运行程序都关闭了,我就退出了Ubuntu。
附加信息:
就在一切关闭和我被注销之前,我在终端上看到了一条错误消息。我迅速地截图了一下,看看上面写着什么:
Traceback (most recent call last):
File "airodump-call.py", line 3, in <module> o_airodump, unused_stderr = airodump.communicate(timeout=15)
File "/usr/lib/python3.5/subprocess.py", line 1072, in communicate stdout, stderr = self.communicate(input, endtime, timeout)
File "usr/lib/python3.5/subprocess.py", line 1713, in _communicate raise TimeoutExpired(self.args, orig_timeout)
subprocess.TimeoutExpired: Command '['airodump-ng', 'mon0', '-w', 'pythonTest']' timed out after 15 seconds发布于 2020-06-14 10:30:44
我也遇到过同样的问题。尽管这是一个旧的帖子,我张贴我的解决方案,因为它可以帮助某人寻找这个。
假设我像运行OP一样运行airodump-ng:
proc = subprocess.Popen(['airodump-ng', 'wlan0mon'])
这可以通过为进程的pid发送SIGINT信号来终止:
os.kill(proc.pid, signal.SIGINT)
注意:您需要import os和import signal
https://stackoverflow.com/questions/38931002
复制相似问题