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

windows 端口转发工具_iox:一款功能强大的端口转发amp;内网代理工具

900cf1096f097890e316ecc1547eb1d3.png

iox是一款功能强大的端口转发&内网代理工具,该工具的功能类似于lcx和ew,但是iox的功能和性能都更加强大。

实际上,lcx和ew都是非常优秀的工具,但还是有地方可以提升的。在一开始使用这些工具的一段时间里,那些复杂的命令行参数是很难记忆的,比如说tran、slave、rcsocks和sssocks等等。这些工具的工作机制非常清晰,明明可以用简单的参数来表示的,为什么要用这么复杂的参数来代替呢?除此之外,这些工具的网络编程逻辑也是可以优化的。比如说,在运行“lcx -listen 8888 9999”命令时,客户端必须先连接“:8888”,再连接“:9999”,实际上这两个端口的连接是没有顺序限制的,但是在iox里则没有这样的限制。再比如说,运行“lcx -slave 1.1.1.1 8888 1.1.1.1 9999”命令时,lcx会以串行的方式连接两个主机,但是并发连接两个主机会更高效,毕竟是纯I/O操作,而iox就是以这种更高效的方式实现的。

当然了,iox还提供了流量加密功能,你甚至还可以直接将iox当做一个简易的ShadowSocks来使用。除此之外,iox还提供了UDP流量转发的功能。

因为iox是采用Go编写的,所以静态连接的程序有一点大,原程序有2.2MB,而UPX压缩后只有800KB。

工具特性

1、流量加密(可选)

2、友好的命令行参数

3、逻辑优化

4、UDP流量转发

工具下载

广大研究人员可以使用下列命令将该项目源码克隆至本地:

git clone https://github.com/EddieIvan01/iox.git

工具使用

大家可以看到,iox所有的参数都是统一格式的,-l/—local代表监听本地端口;-r/—remote代表连接远端主机。

两种工作模式

fwd模式:

同时监听 0.0.0.0:8888 和0.0.0.0:9999,将两个连接间的流量进行转发。

./iox fwd -l 8888 -l 9999for lcx:./lcx -listen 8888 9999

监听0.0.0.0:8888,把流量转发到1.1.1.1:9999。

./iox fwd -l 8888 -r 1.1.1.1:9999for lcx:./lcx -tran 8888 1.1.1.1 9999

连接1.1.1.1:8888和1.1.1.1:9999, 在两个连接间转发流量。

./iox fwd -r 1.1.1.1:8888 -r 1.1.1.1:9999for lcx:./lcx -slave 1.1.1.1 8888 1.1.1.1 9999

proxy模式:

在本地 0.0.0.0:1080启动Socks5服务

./iox proxy -l 1080for ew:./ew -s ssocksd -l 1080

在目标主机上开启Socks5服务,将通信流量转发至公网VPS,VPS上将流量从0.0.0.0:9999转发到0.0.0.0:1080。此时,你必须将两条命令成对使用,因为它内部包含了一个简单的协议来控制回连。

./iox proxy -r 1.1.1.1:9999./iox proxy -l 9999 -l 1080       // 注意,这两个端口是有顺序的for ew:./ew -s rcsocks -l 1080 -e 9999./ew -s rssocks -d 1.1.1.1 -e 9999

接下来,连接内网主机:

# proxychains.conf# socks5://1.1.1.1:1080$ proxychains rdesktop 192.168.0.100:3389

启用加密功能

比如说,我们想要将内网3389端口的数据转发至VPS:

// 目标主机./iox fwd -r 192.168.0.100:3389 -r *1.1.1.1:8888 -k 656565// 我们的VPS./iox fwd -l *8888 -l 33890 -k 656565

此时,目标主机和VPS:8888之间的流量将会被加密,预共享的密钥是’AAA’,iox会用这个密钥生成种子密钥和nonce(正常来讲,不应该复用nonce。但是考虑到iox的加密功能仅仅为了绕过IDS等设备,为了不额外分配空间,TCP流加密会复用nonce),并用Xchacha20流加密 (在v0.3版本中用Xchacha20替换掉了AES-CTR)。

因此,“*”符号应该成对使用:

./iox fwd -l 1000 -r *127.0.0.1:1001 -k 000102./iox fwd -l *1001 -r *127.0.0.1:1002 -k 000102./iox fwd -l *1002 -r *127.0.0.1:1003 -k 000102./iox proxy -l *1003 -k 000102$ curl google.com -x socks5://127.0.0.1:1000

除此之外,你还可以把iox当作一个简单的ShadowSocks来使用:

// ssserver./iox proxy -l *9999 -k 000102// sslocal./iox fwd -l 1080 -r *VPS:9999 -k 000102

UDP转发

此时,我们只需要在命令行参数中添加一个“-u”即可:

./iox fwd -l 53 -r *127.0.0.1:8888 -k 000102 -u./iox fwd -l *8888 -l *9999 -k 000102 -u./iox fwd -r *127.0.0.1:9999 -r 8.8.8.8:53 -k 000102 -u

注意:当你做多级连接的转发时,Remote2Remote-UDP-mode必须最后一个被启动,也就是上面示例中的第三条命令。其次,UDP转发可能会有一些不合预期的行为。

许可证协议

iox的开发与发布遵循MIT开源许可证协议。

7da88fa0931d5e2eb4d278ce50bafb1c.gif

精彩推荐

6f926289356c2fb0b5b0c3ab2d5f6c23.png e47f7ec960b11addf11c86a7660b200f.png 19c1ac815a1c5c2364b8a076874b90ea.png

fe9f2d9d9c272bb6a0aa8593638efa19.png

56ee6cb7f7ef50994afb06d9cefdb16a.pnge3542fc689e7cdf9291bc7b066e206a1.png

436402b352d94ae414c1be25d0a9886b.gif

相关文章:

  • python语言format用法_python format用法详解
  • python的前端怎么实现_python 前端HTML
  • python读取文件大小_Python如何批量获取文件夹的大小并保存
  • python ocr高精度识别_OCR识别-python版(一)
  • python 全部缩进一行_一步一步学Python3(小学生也适用) 第三篇: Python基本规范
  • win10添加python环境变量_Windows10下安装python(配置环境变量)
  • python运维开发前景_运维开发前景怎么样,怎么去学习运维开发?
  • .sh文件怎么运行_创建优化的Go镜像文件以及踩过的坑
  • css 动态rem_我们为什么不使用 CSS 框架
  • 电脑控制苹果手机_用电脑控制手机?
  • close wait 过多原因_springboot tomcat 挂掉,假死无响应原因总结和解决方案
  • python tkinter_tkinter转盘抽奖代码、调整和逐步优化的python分析
  • path manipulation怎么解决_TensorFlow Object Detection API遇到的问题及解决
  • python安装后怎样配解释器_pycharm 安装后如何设置与更换解释器
  • cloud压缩怎么彻底删除_怎么彻底删除mysql服务?
  • 【许晓笛】 EOS 智能合约案例解析(3)
  • 【跃迁之路】【477天】刻意练习系列236(2018.05.28)
  • 〔开发系列〕一次关于小程序开发的深度总结
  • 30天自制操作系统-2
  • Angular js 常用指令ng-if、ng-class、ng-option、ng-value、ng-click是如何使用的?
  • java正则表式的使用
  • JS学习笔记——闭包
  • opencv python Meanshift 和 Camshift
  • python3 使用 asyncio 代替线程
  • STAR法则
  • UEditor初始化失败(实例已存在,但视图未渲染出来,单页化)
  • vue从创建到完整的饿了么(18)购物车详细信息的展示与删除
  • 从零到一:用Phaser.js写意地开发小游戏(Chapter 3 - 加载游戏资源)
  • 从零开始的无人驾驶 1
  • 基于Javascript, Springboot的管理系统报表查询页面代码设计
  • 使用 @font-face
  • 使用putty远程连接linux
  • 思否第一天
  • 通过git安装npm私有模块
  • 一文看透浏览器架构
  • 用简单代码看卷积组块发展
  • 在Mac OS X上安装 Ruby运行环境
  • ​queue --- 一个同步的队列类​
  • #HarmonyOS:软件安装window和mac预览Hello World
  • #单片机(TB6600驱动42步进电机)
  • #控制台大学课堂点名问题_课堂随机点名
  • $().each和$.each的区别
  • (03)光刻——半导体电路的绘制
  • (23)Linux的软硬连接
  • (windows2012共享文件夹和防火墙设置
  • (搬运以学习)flask 上下文的实现
  • (附源码)spring boot基于小程序酒店疫情系统 毕业设计 091931
  • (附源码)基于ssm的模具配件账单管理系统 毕业设计 081848
  • (算法设计与分析)第一章算法概述-习题
  • (未解决)macOS matplotlib 中文是方框
  • (一)WLAN定义和基本架构转
  • (原創) 如何動態建立二維陣列(多維陣列)? (.NET) (C#)
  • (转)Spring4.2.5+Hibernate4.3.11+Struts1.3.8集成方案一
  • ****** 二十三 ******、软设笔记【数据库】-数据操作-常用关系操作、关系运算
  • .360、.halo勒索病毒的最新威胁:如何恢复您的数据?