项目地址:https://github.com/ph4ntonn/Stowaway
Stowaway是一个利用go语言编写的多级代理工具,其灵感来自于Dliv3师傅的Venom工具(感谢Dliv3师傅 XD ),正好自己也想写些东西来练练手,于是就写了这一个小工具 :)
用户可使用此程序将外部流量通过多个节点代理至内网,并实现管理功能
PS:demo文件夹下为其雏形demo,亦可使用,详见demo文件下的readme文件
此工具仅限于安全研究和教学,用户承担因使用此工具而导致的所有法律和相关责任! 作者不承担任何法律和相关责任!
Stowaway分为admin端和agent端两种形式
不想编译的盆油可以直接用release下编译完成的程序
简单示例:
Admin端:./stowaway admin -l 9999 -s 123
命令解析:
admin代表以admin模式启动
-l 参数代表监听端口
-s 参数代表节点通信加密密钥(admin端与agent端必须一致!)
暂时就这两个参数!!!!!!
agent端: ./stowaway agent -m 127.0.0.1:9999 -l 10000 --startnode -s 123 -r
命令解析:
agent代表以agent端模式启动
-m 代表上一级节点的地址
-l 代表监听端口
-s 参数代表节点通信加密密钥(admin端与agent端必须一致!)
--startnode 代表此节点是agent端的第一个节点(第一个节点必须加上--startnode选项!若无--startnode表示为普通节点,命令与startnode一致)
-r 代表以反向模式启动(即下级节点需要本节点主动连接而不是等待下级节点主动连接到本节点,若正向连接可以去除此选项)
暂时就这五个参数!!!!!!
一个简单的例子(以一个admin端三个agent端为例):
Admin端:
Startnode端:
第一个普通Node(设置为反向连接模式):
此时,进入(use命令,本例中为use 1)此节点的上级节点(即startnode),利用命令connect 127.0.0.1:10001 即可将此反向模式节点加入网络
第二个普通Node:
连入完成后,admin端查看节点:
此时在admin端操控第二个普通node节点:
打开远程shell:
此时就可以在admin端操纵第二个普通节点的shell
打开socks5代理:
此时用户即可以将admin端的7777端口作为socks5代理端口,将流量代理至第二个普通node节点(当想关闭socks服务时,在节点模式下输入stopsocks即可关闭与此节点相关的socks代理服务)
打开ssh:
此时就可以在admin端将ssh流量代理至第二个普通节点,由第二个普通节点来访问指定的ssh服务
PS: 在ssh模式下,你可以用pwd来判断自己所处的文件夹(好吧,其实就是没法把banner传回来。。)
上传/下载文件:
上传下载功能命令为 upload/download 后加文件路径(注意要在节点模式下使用),此时就可以上传文件至指定节点/下载指定节点的文件
具体命令使用可输入help查询