【发布时间】:2016-08-13 08:53:31
【问题描述】:
我要做的是每 10 秒记录一次 airodump-ng 的输出。
第一次尝试:
通过 airodump-ng documentation 他们提到了这样一个命令 --write-interval
当我尝试使用它时:sudo airodump-ng mon0 -w testOutput --write-interval 10 -o csv,我得到了--write-interval 是一个无法识别的选项的错误。
第二次尝试: 我自己尝试在 Python 中这样做。然后我遇到了试图停止这个过程的问题。我得到的最接近的是this solution。
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
【问题讨论】:
-
如果你不使用
sudo(也许用sudo运行python)也会发生这种情况吗? -
同样的事情发生了——所有程序都关闭了,我退出了 Ubuntu。
-
这可能是一些驱动问题或什么的。您可能想要检查系统的日志。或者用
airodump-ng搜索类似的问题,比如askubuntu.com/questions/786223/…是不是只有在使用python的时候才会出现这个问题?尝试运行sudo airodump-ng mon0 -w testOutput | echo看看是否得到相同的结果;当 airodump-ng 无法再写入输出时,它可能会做一些奇怪的事情。 -
@mweerden 写作适用于终端中的单次运行。问题是我无法在 Python 中停止该过程(不关闭所有内容并将我注销),然后再次重新启动它以再进行 10 秒的间隔录制。
-
@AlonBresler 还有
| echo?在任何情况下,您都可以捕获它并使用kill(),而不是让TimeoutExpired终止您的脚本。另一种选择是使用terminate()或send_signal(signal.SIGINT)。后者可能与您在终端中终止airodump-ng的方式最相似。
标签: python ubuntu pipe subprocess aircrack-ng