首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从脚本运行airodump-ng

从脚本运行airodump-ng
EN

Security用户
提问于 2017-09-17 19:10:53
回答 1查看 2.2K关注 0票数 0

我正在写一个运行airodump-ng的脚本。我使用以下命令:

代码语言:javascript
复制
timeout -sHUP 1m airodump-ng -d MYBSSID -w wpahandshake wlan0mon

当我从命令行运行它时,它可以工作,但是当我从脚本运行它时,它会创建一个空的.cap文件。有人能解释原因和解决办法吗?

EN

回答 1

Security用户

回答已采纳

发布于 2018-05-08 08:39:26

这是一个存在于airodump-ng1.2 rc4 (2016年2月14日发布)到airodump ng1.2(2018年4月15日发布)的bug。

但2018年4月18日,GitHub用户Mister解决了这个问题。见提交

在带有bug的src/airodump-ng.c中,它将使用input_thread()创建一个线程,而不管在前台还是后台运行的是airodump-ng进程。

input_thread()会给mygetch()打电话。mygetch()会给getchar()打电话。因此,在后台运行时,airodump-ng进程将读取stdin。

在Linux中,如果进程在后台运行时读取stdin,它将被停止。运行不带timeout--foreground选项将允许在后台运行COMMAND,这里是airodump-ng。因此,在这种情况下,airodump-ng将被停止并创建一个空的.cap文件(由您询问)。

解决你的问题有两种思路:

  1. 通过使用--foreground选项timeout或运行source <your_orignal_script.sh>,让airodump-ng在前台运行。
  2. 在后台运行时,不要让airodump-ng读取stdin,方法是将stdin重定向到/dev/null、timeout -sHUP 1m airodump-ng -d MYBSSID -w wpahandshake wlan0mon < /dev/null或下载最新的源代码,而不需要从GitHub下载bug,然后编译并安装它。
票数 2
EN
页面原文内容由Security提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://security.stackexchange.com/questions/169629

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档