跳板攻击之:EarthWorm代理转发

1 EarthWorm官方介绍

  • EarthWorm是一款用于开启 SOCKS v5 代理服务的工具,基于标准 C 开发,可提供多平台间的转接通讯,用于复杂网络环境下的数据转发。
  • 下载地址:rootkiter/EarthWorm: Tool for tunnel (github.com)
  • 软件位置:.\EarthWorm\server\download

2 官方使用方法:

该工具共有 6 种命令格式(ssocksd、rcsocks、rssocks、lcx_slave、lcx_listen、lcx_tran)。

  • 其中 SOCKS5 服务的核心逻辑支持由 ssocksd 和 rssocks 提供,分别对应正向与反向socks代理。
  • 其余的 lcx 链路状态用于打通测试主机同 socks 服务器之间的通路。
  • lcx 类别管道:
    • lcx_slave: 该管道一侧通过反弹方式连接代理请求方,另一侧连接代理提供主机。
    • lcx_tran: 该管道,通过监听本地端口接收代理请求,并转交给代理提供主机。
    • lcx_listen:该管道,通过监听本地端口接收数据,并将其转交给目标网络回连的代理提供主机。

2.1 环境

2.2 正向 SOCKS v5 服务器

  1. 实现:让外网kali通过对外服务器Win10访问内网CentOS

  2. 对外服务器Win10上执行

    ew_for_win_32.exe -s ssocksd -l 1080
  3. kali上配置

    vim /etc/proxychains4.conf
    socks5 192.168.50.236 1080
  4. 成功访问到内网

2.3 反弹 SOCKS v5 服务器

  1. 实现:让外网kali通过对内网CentOS反弹的SOCKS v5 访问内网CentOS

  2. 外网kali上运行以下命令:

    # 监听1080端口,1080接收的数据通过8888交互传递
    ./ew_for_linux -s rcsocks -l 1080 -e 8888
  3. Win10上启动 SOCKS v5 服务 并反弹到公网主机的 8888端口

    # 开启反向socks服务。反向连接vps(kali)的8888端口
    ./ew_for_linux -s rssocks -d 192.168.50.2 -e 8888
  4. kali上配置

    vim /etc/proxychains4.conf
    socks5 127.0.0.1 8080
  5. 成功访问到内网

2.4 多级级联

2.4.1 正向多级级联

  1. 实现:让外网kali通过对外服务器Win10代理转发到内网CentOS上访问内网CentOS2主机

  2. kali上执行

    # 监听1080端口,1080接收的数据通过8888交互传递
    ./ew_for_linux -s lcx_listen -l 1080 -e 8888 # 配置proxychains
    vim /etc/proxychains4.conf
    socks5 127.0.0.1 1080
  3. 在内网CentOS上执行

    # 开启正向socks服务
    ./ew_for_linux -s ssocksd -l 9999
    • 注意:防火墙要放行相应端口
  4. 在Win10上执行

    # 作为中间角色,反向连接vps(kali)的8888,正向连接Innet2(CentOS2)的9999。打通两者
    ew_for_win_32.exe -s lcx_slave -d 192.168.50.2 -e 8888 -f 10.0.0.7 -g 9999
  5. 成功连接内网10.1.1.0/24网段

2.4.2 反向多级级联

  1. 实现:让内网CentOS反弹的SOCKS v5 通过对外服务器Win10代理转发,反向连接外网kali。最终实现让外网kali内网CentOS2访问。

  2. kali上执行

    ./ew_for_linux -s rcsocks -l 1080 -e 8888
    
    # 配置proxychains
    vim /etc/proxychains4.conf
    socks5 127.0.0.1 1080
  3. 在win10上执行

    # 监听1080端口,1080接收的数据正向传给forward_ip(kali)的8888端口
    ew_for_win_32.exe -s lcx_tran -l 9999 -f 192.168.50.2 -g 8888
  4. 在内网CentOS上执行

    /ew_for_linux -s rssocks -d 10.0.0.6 -e 9999
  5. 成功连接内网10.1.1.0/24网段

2.4.3 三级级联本地SOCKS测试用例

卷不动了,有兴趣的测试下

$ ./ew -s rcsocks -l 1080 -e 8888
$ ./ew -s lcx_slave -d 127.0.0.1 -e 8888 -f 127.0.0.1 -g 9999
$ ./ew -s lcx_listen -l 9999 -e 7777
$ ./ew -s rssocks -d 127.0.0.1 -e 7777
  • 数据流向: SOCKS v5 -> 1080 -> 8888 -> 9999 -> 7777 -> rssocks

3 补充说明:

  1. 为了减少网络资源的消耗,程序中添加了超时机制,默认时间为10000毫秒(10秒),用户可以通过追加 -t 参数来调整这个值,单位为毫秒。在多级级联功能中,超时机制将以隧道中最短的时间为默认值。
  2. 多级级联的三种状态可以转发任意以TCP为基础的通讯服务,包括远程桌面/ssh 服务等。
  3. ew_for_arm_32 在android手机、小米路由器和树莓派 上测试无误

跳板攻击之:EarthWorm代理转发的更多相关文章

  1. ssh代理转发

    实验环境 serverA:172.16.2.116 serverB:172.16.2.225 serverC:172.16.2.115 "代理转发"是针对ssh认证过程的一种转发 ...

  2. curl运行json串,代理转发格式

    curl -b 'uin=o0450654733; skey=@tq9xjRvYy' -H "Content-Type: application/json" -X POST -d ...

  3. windows下使用密钥登录Linux及xshell代理转发

    1.密钥登录原理 一般我们使用xshell访问远程主机(Linux主机)时,都是先请管理员给我们开一个账户,即为我们设置一个一个用户名和对应的密码,然后我们就可以使用下面的方式登录到远程主机了: 在这 ...

  4. IIS充当代理转发请求到Kestrel

    接着上篇博文为ASP.NetCore程序启用SSL的code,这篇将介绍如何用IIS充当反向代理的角色转发请求到Kestrel服务器 与ASP.NET不同,ASP.netCore使用的是自托管web服 ...

  5. Nginx代理转发Apache+svn

    1.安装svn和httpd yum install httpd yum install subversion mod_dav_svn 创建仓库目录 mkdir -p /var/www/svn 3.创建 ...

  6. nginx反向代理转发后页面上的js css文件无法加载【原创】

    故障现象:nginx做代理转发后,发现页面上的js css文件无法加载,页面样式乱了. 原因:没有配置静态资源 解决js css文件无法加载无法访问的问题 解决办法: 修改配置文件nginx.conf ...

  7. Docker Kubernetes hostPort 代理转发

    Docker Kubernetes  hostPort 代理转发 hostPort: 1. 类似docker -p 映射宿主级端口到容器. 2. 容器所在的主机暴露端口转发到指定容器中. 3. hos ...

  8. IIS充当反向代理转发请求到Kestrel

    接着上篇博文为ASP.NetCore程序启用SSL的code,这篇将介绍如何用IIS充当反向代理的角色转发请求到Kestrel服务器 介绍 与ASP.NET不同,ASP.netCore使用的是自托管w ...

  9. iis和apache共用80端口,IIS代理转发apache

    为什么共用80端口应该不用多说了,服务器上程序运行环境有很多套,都想抢用80端口,所以就有了共用80端口的解决方案. 网上很多的教程一般都是设置APACHE使用默认80端口,代理转发IIS的网站,II ...

  10. (转)基于live555的流媒体代理转发服务器

    对于并发量并不大而且对性能要求不是很高的流媒体传输模块,live555还是很好的选择,下面说一下我所实现的流媒体代理服务器(目前只能实现对H264单视频的转发)代理转发主要 对于并发量并不大而且对性能 ...

随机推荐

  1. 函数调用时用const保护指针

    当调用函数并且把指向变量的指针作为参数传入时,通常会假设函数将修改变量(否则,为什么函数需要指针呢?).例如,如果在程序中看到语句 f(&x); 大概是希望f改变x的值.但是,f仅需检查x的值 ...

  2. php+apache环境搭建

    [先安装apache] apache快速安装:https://www.cnblogs.com/brad93/p/16718104.html PHP安装教程参考:https://www.cnblogs. ...

  3. 18V转5V,15V转5V的LDO和DC芯片方案

    18V 转 5V, 15V 转 5V 的 LDO:芯片的选择,特别是输入电压,在低电平 5V 以下的,基本上都是接近也可以.但是 5V 以上,如现在的 18V 和 15 的话,就不一样了.我们需要在选 ...

  4. 5V升压8.4V,5V转8.4芯片电路图

    PW5300是电流模式升压DC-DC转换器.其内置0.2Ω功率MOSFET的PWM电路使该稳压器具有效高的功率效率.内部补偿网络还可以程度地减少了6个外部元件的数量.误差放大器的同相输入接到0.6V精 ...

  5. 万字干货|Synchronized关键字详解

    作者:小牛呼噜噜 | https://xiaoniuhululu.com 计算机内功.JAVA底层.面试.职业成长相关资料等更多精彩文章在公众号「小牛呼噜噜」 前言 大家好,我是呼噜噜,在之前的文章中 ...

  6. <一>C++ STL

    STL (standard template libaray - 标准模板库):是 C++ 标准库的重要组成部分,不仅是一个可复用的组件库,而且是一个包罗数据结构与算法的软件框架. 通俗来说:STL就 ...

  7. jmeter 之修改报告取样间隔时间以及APDEX 区间设置

    1.取样间隔时间设置 在jmeter 生成的报告中取样间隔默认设置的是1分钟,而非1秒,故样本间的间隔为1分钟,如下图所示: 取样间隔时间可通过修改bin/user.properties配置文件实现自 ...

  8. 升级csproj文件为vs2017工程格式(SDK样式)

    csproj文件在VS2017后格式变更为SDK样式.framework项目如果需要源链接等等功能,需要进行手动升级. 升级过程 升级需要Project2015To2017Nuget包. > d ...

  9. 增强MybatisPlus拓展新功能 实战MybatisPlus大合集

    mybatis-plus-max简介 MybatisPlusMax是MybatisPlus的增强包,秉承只拓展不修改的理念,对MybatisPlus做增强. 正如MybatisPlus是对MyBati ...

  10. python之路48 django 视图层、模板层

    视图层之必会三板斧 用来处理请求的视图函数都必须返回HttpResponse对象 完全正确 class HttpResponse: pass return HttpResponse() def ren ...