掉线问题
在渗透测试过程中,一般VPN代理来进行渗透,但是如果VPN突然掉线了,那么就很可能使用我们的真实IP就暴露了。如何保证一旦VPN掉线就自动断网?
Windows自带VPN与第三方VPN区别
阅读了前辈的若干文章如:https://fstraw.cn/posts/f6240f8d
核心思路
核心思路是通过Windows防火墙的出站规则限制上网
1 | netsh advfirewall set allprofiles firewallpolicy allowinbound,blockoutbound |
- 设置防火墙默认允许所有入站,阻止所有出站
- 添加出站规则,允许
8.8.8.8
,也就是允许出站VPN服务器 - 添加出站规则,允许接口类型为
远程访问
,也就是允许通过VPN接口出站
第三方VPN客户端的问题
经测试其能解决使用Windows自带VPN连接后的掉线,但第三方VPN客户端的情况,会导致不管连接不连接VPN都断网。
重点就是第三条,Windows防火墙对远程访问
的接口类型解释为
远程访问: 此规则只适用于通过已在计算机上配置的远程访问 [例如虚拟专用网络 (VPN) 连接或拨号连接] 发送的通信。
而第三方VPN客户端一般都是安装一个虚拟网卡,我猜测就是因为虚拟网卡的接口类型并非远程访问
类型,导致彻底断网。
解决办法
假设VPN服务器地址为8.8.8.8
,连接后分配地址为192.168.30.0/24
段
使用以下命令即可实现VPN掉线自动断网,区别只有最后一行。
由于无法通过接口类型判断,所以通过VPN网卡的本地地址判断是否能出网。
1 | netsh advfirewall set allprofiles firewallpolicy allowinbound,blockoutbound |
恢复使用如下命令
1 | netsh advfirewall set allprofiles firewallpolicy allowinbound,allowoutbound |