forwardPort Go 语言的端口转发工具

Linux安全
1156
linux
linux 举报
2021-06-09

端口转发/映射工具 forward for port data

编译:

配置好你的GO开发环境,推荐GO 1.7以上;

执行build.dat,会自动编译出linux和windows的执行程序,文件名分别为:“forwardPort”、“forwardPort.exe”

为了方便大家使用,我将已编译好的二进制文件也提供给大家:

Windows-64位:

https://github.com/tavenli/forwardPort/releases/download/1.0/forwardPort-win-64.zip

Linux-64位:

https://github.com/tavenli/forwardPort/releases/download/1.0/forwardPort-linux-64.zip

场景1:

工作中,有时候会碰到A服务器可以访问B服务器,但是你只能访问到A服务器,B服务器限制了只有A服务器能访问它;如果你需要访问B服务器,必须通过A服务器跳一次。

forwardPort工具就是可以让你在A服务器上开启一个端口,当你访问A服务器上的端口时,实际访问的是B服务器的某个端口。

操作步骤:

A服务器IP:10.10.1.100

B服务器IP:10.11.2.20

1、在A服务器上执行:

forwardPort.exe

(注:linux系统执行 ./forwardPort)

2、执行成功后,默认监听8000端口,这时打开浏览器,访问:http://10.10.1.100:8000/ServerSummary  会返回当前程序的统计信息,返回内容为JSON数据。

如果访问不了,请检查A服务器上防火墙是否开启8000端口的访问。

3、开启转发,将A机器上的8010端口转发到B服务器上的3389端口:

http://10.10.1.100:8000/ForwardWork?auth=taven123&status=1&fromAddr=:8010&toAddr=10.11.2.20:3389

4、开启后,您就可以通过 10.10.1.100:8010 端口连接了,此时你实际连接到的是 10.11.2.20 上的 3389

上面只是个例子,你可以随时启用任意端口与任意机器之间的端口映射。

当你使用完毕后,可以立即关闭端口转发,只需要执行如下请求即可:

http://10.10.1.100:8000/ForwardWork?auth=taven123&status=0

执行后,端口转发关闭,端口被释放。

其它说明

windows-64下:

> forwardPort.exe

> forwardPort.exe -auth 123 -restApi 10.10.1.100:9999

linux-64下:

$ ./forwardPort

$ ./forwardPort -auth 123 -restApi 10.10.1.100:9999
参数说明:

auth:rest接口调用时的密码,启动时不带该参数,则默认为:taven123

restApi:rest接口监听的地址,启动时不带该参数,则默认为:0.0.0.0:8000

#REST接口参数说明:

/ForwardWork?auth=taven123&status=1&fromAddr=:8010&toAddr=10.11.2.20:3389

auth:密码,默认为taven123

status:如果是开启转发,则为1,如果是关闭转发,则为0

fromAddr:要用来在A机器上监听的一个端口,用来给客户端连接

toAddr:把fromAddr端口的数据转发到哪个IP的端口上

如果是本机内转发,可以这样:
/ForwardWork?auth=taven123&status=1&fromAddr=:8010&toAddr=:22

表示把机器上的8010端口映射到本机的22端口.


倒序看帖 只看楼主
热点关注
/lib/ld-linux.so.2: bad ELF interpreter: No such file or directory
服务停止、启动、重启一体化脚本,万能语言启动脚本
shell参数判断
在后台用进程名运行bash脚本
shell脚本每行后面多了一个^M的原因和解决办法
定时检测服务,检测down掉后重启。系统检测到DMSERVER运行正常
挂载磁盘的时候遇到一个问题,挂载完磁盘之后重启服务器挂载的盘丢失了.
中标麒麟系统Your trial is EXPIRED and no VALID licens
termux 开启ssh并用用户名和密码登陆
组成共享库的目标文件和一般的目标文件有所不同,在编译时要加-fPIC和-share选项,例如:
gcc指定链接库路径后还是找不到库文件
./configure -build,-host,-target设置
shell脚本每行后面多了一个^M的原因和解决办法
shell 中 if [ “x${var}“ == “x“ ] 中 x的作用
查看linux机器是32位还是64位的方法