端口转发 Port Forwarding (一)
0x00First
最近发现一些好用的端口转发工具和技巧,计划认真梳理一下
SSH、NC、LCX、EW、FRP
0x01 SSH隧道端口转发
目前利用SSH隧道(SSH tunneling)进行端口转发,有三种类型:本地端口转发、远程端口转发、动态端口转发。
1、本地端口转发
在ip1的客户端执行如下命令:
SSH -CfN -L 0.0.0.0:port1:ip2:port2 user3@ip3
结果:访问ip1:port1等同于访问ip2:port2
条件:ip1可以ssh访问ip3;
ip3可以访问ip2的port2
1.5、本地转发与远程端口转发的异同
同:都是通过访问ip1:port1来最终访问ip2:port2
ip3是中间必经点,ip2只能通过ip3来发起访问
异:前者是ip1扮演SSH Client,后者是ip3扮演SSH Client
前者场景-公司里只有老板的ip3可以到看ip2上的片片,由于你加班表现优异,特奖励你的ip1可以ssh他的ip3,这样你在自己的工位上也能看ip2的片了。
后者场景-老板把公司内网的考勤系统ip2,通过可以上网的ip3主动映射到互联网的服务器ip1上,便于出差在外/半夜在家的你加班。
2、远程端口转发
在ip3的客户端执行如下命令:
SSH -CfN -R port1:ip2:port2 user1@ip1
结果:访问ip1:port1等同于访问ip2:port2
条件:ip3可以ssh访问ip1;
ip3可以访问ip2的port2
3、动态端口转发
在ip1的客户端执行如下命令:
SSH -CfN -D 8080 user3@ip3
在ip1上将socks5代理服务器地址设置为ip1:8080
结果:在ip1上可以访问ip3所有能访问的
条件:ip1可以ssh访问ip3
0x02 NetCat NC端口转发
目前windows版本的通用netcat没有见到可有进行端口转发的,Linux版的也只是能进行简单的端口转发。Linux端口转发是需要同mkfifo结合起来用的:
在ip1上:
mkfifo /tmp/backpipe
cat /tmp/backpipe | nc ip2 8080 | nc -l 9090 > /tmp/backpipe
结果:访问ip1的9090就是访问ip2的8080了
条件:ip1可以访问ip2的8080
0x03 LCX 端口转发
应该说LCX是比较经典的端口转发工具,先上一段官方说明:
Usage of Packet Transmit:
./lcx -<listen|tran|slave> <option> [<-log|-hex|-text> file]
./lcx -about
[options:]
-listen <local port1> <local port2>
-tran <local port> <remote host> <remote port>
-slave <remote host1> <remote port1> <remote host2> <remote port2>
-hex : hex mode data dump
-text : text mode data dump
-log : save transfer log
0x04 EarthWorm EW 端口转发
EarthWorm EW是一款跨平台的端口转发、Socks5代理工具,自带LCX功能,跨平台。(Earthworm 工具网址:http://rootkiter.com/EarthWorm)
EW共有 6 种工作模式:ssocksd、rcsocks、rssocks、lcx_slave、lcx_listen、lcx_tran
1、正向SOCKS5 代理
在ip1上命令:ew -s ssocksd -l 8080
将ip2的socks5代理服务器设置为:ip1:8080
结果:ip1能访问的端口,ip2都能访问
条件:ip2能够访问ip1的8080
2、反弹SOCKS5 代理
在ip1上命令:ew -s rcsocks -l 8080 -e 9090
在ip2上命令:ew -s rssocks -d ip1 -e 9090
将ip3的socks5代理服务器设置为:ip1:8080
结果:ip2能访问的端口,ip3都能访问
条件:ip2能够访问ip1的9090
ip3能够访问ip1的8080
0x05 FRP 端口转发
FRP 是一个可用于内网穿透的高性能的反向代理应用,支持 tcp, udp, http, https 协议。(官方文档很详细,我都不想说了)
0xRef
1、《SSH/OpenSSH/PortForwarding 》https://help.ubuntu.com/community/SSH/OpenSSH/PortForwarding
2、《实战 SSH 端口转发》https://www.ibm.com/developerworks/cn/linux/l-cn-sshforward/
3、《端口转发》https://pan.baidu.com/s/1ystFF-a0nBSDvINpzf0OZw
4、《应用netcat实现端口转发》https://blog.csdn.net/freestyle4568world/article/details/54693306
5、《netcat的端口转发功能的实现》https://blog.csdn.net/whackw/article/details/46414069
6、《netcat的正确打开方式》 https://www.jianshu.com/p/827f5dc79bbe
7、《PuTTY/Putty建立隧道的方法》https://blog.csdn.net/lifan5/article/details/33709271
8、《三种不同类型的ssh隧道》http://hetaoo.iteye.com/blog/2299123
9、《SSH的端口转发:本地转发Local Forward和远程转发Remote Forward》https://blog.csdn.net/a351945755/article/details/21785647
10、《ssh端口映射总结》https://blog.csdn.net/boliang319/article/details/48656985
11、《端口转发工具lcx使用两类》https://www.cnblogs.com/lingerhk/p/4506308.html
12、《内网端口转发及穿透》http://www.zerokeeper.com/experience/network-port-forwarding-and-penetration.html
13、《内网穿透大杀器--EarthWorm》https://blog.csdn.net/nzjdsds/article/details/82025651
14、《FRP 中文说明文档》https://github.com/fatedier/frp/blob/master/README_zh.md
0xApp
1、SSH 命令详解
https://www.cnblogs.com/f-ck-need-u/archive/2017/07/05/7120669.html
2、25个常用的ssh命令
https://blog.csdn.net/u010027484/article/details/51774083
端口转发 Port Forwarding (一)的更多相关文章
- 路由器port触发与转发---Port Forwarding & Port Triggering
What is Port Triggering? If you have not read my explanation of port forwarding do so now. You can f ...
- iptables 通讯端口转接(Port Forwarding)
是一种特殊的DNAT操作,其作用是让一部电脑(通常是防火牆)担任其它电脑的代理伺服器(proxy).防火牆接收外界网络接传给它自己的包,然后改写包的目的地位址或目的端口,使其像是要送到內部网路其它电脑 ...
- OpenSSH高级功能之端口转发(Port Forwarding)
在RedHat提供的系统管理员指南中提到OpenSSH不止是一个安全shell,它还具有X11转发(X11 Forwarding)和端口转发(Port Forwarding)的功能.X11功能一般用于 ...
- SSH Tunnel扫盲(ssh port forwarding端口转发)
SSH的的Port Forward,中文可以称为端口转发,是SSH的一项非常重要的功能.它可以建立一条安全的SSH通道,并把任意的TCP连接放到这条通道中.下面仔细就仔细讨论SSH的这种非常有用的功能 ...
- [转] SSH原理与运用(2):远程操作与端口转发
英文:阮一峰 链接:http://www.ruanyifeng.com/blog/2011/12/ssh_port_forwarding.html 接着前一次的文章,继续介绍SSH的用法. (Imag ...
- virtualbox端口转发
端口转发:setting->network->adapter:attached to NAT.port forwarding rules->name protocol ...
- vbox端口转发
端口转发:setting->network->adapter:attached to NAT.port forwarding rules->name protocol ...
- 玩转SSH端口转发
SSH有三种端口转发模式,本地端口转发(Local Port Forwarding),**远程端口转发(Local Port Forwarding)**以及**动态端口转发(Dynamic Port ...
- 005. [转] SSH端口转发
玩转SSH端口转发 SSH有三种端口转发模式,本地端口转发(Local Port Forwarding),远程端口转发(Remote Port Forwarding)以及动态端口转发(Dynamic ...
随机推荐
- mysql出现“Incorrect key file for table”解决办法
本文来自: https://www.cnblogs.com/zjoch/archive/2013/08/19/3267131.html 今天mysql突然出现以下错误: mysql> selec ...
- JDBC测试计划-连接mysql
一.测试环境准备 mysql:5.5 JDBC驱动:mysql-connector-java-5.1.30.jar 文件复制到JMeter/lib目录下 JMeter:jmeter-3.2 ...
- 第九周博客作业 <西北师范大学| 周安伟>
第九周助教作业 助教博客链接https://home.cnblogs.com/u/zaw-315/ 作业要求博客链接https://www.cnblogs.com/nwnu-daizh/p/10726 ...
- 通信导论-IP数据网络基础(3)
ICMP(IP辅助协议)--网际控制报文协议 ICMP报文种类:ICMP差错报文(终点不可达.时间超过等5种)和ICMP询问报文(回送请求和回答请求.时间戳请求和回答报文2种) ICMP是一种集差错报 ...
- android一个app打开另一个app的指定页面
一个app打开另一个app的指定页面方法 有以下几种 1.通过包名.类名 2.通过intent的 action 3.通过Url 方案1. ComponentName componentName = n ...
- MYSQL后更改ROOT的密码后无法启动服务报错1067
安装MYSQL后更改了ROOT的密码后用 net start mysql 启动时报错1067.使用以下命令:1.进入mysql安装目录的bin目录下:cd C:\Program Files\MySQL ...
- GarageBand mac怎么剪切音频片段? GarageBand mac使用教程
garageband mac智能控制轻松修饰声音资源库中任何乐器的音色,让你在世界各地都可以开始你的创意,让世界听到你的歌声.GarageBand mac剪切音频片段的操作小伙伴们也是需要掌握的,Ga ...
- GUI学习之二——PyQt控件初识
一.控件概念 控件是一个程序界面上的各个独立的元素, 它具备用户点击.接收用户输入.展示不同内容.存放其他控件等功能. 二.控件分类 常用的控件按功能可以分为以下几种类 按钮 QPushButton— ...
- AX_xSession
Session xSession = new xSession(); ; xSession.userId();
- 高斯混合模型(GMM) - 混合高斯回归(GMR)
http://www.zhihuishi.com/source/2073.html 高斯模型就是用高斯概率密度函数(正态分布曲线)精确地量化事物,将一个事物分解为若干的基于高斯概率密度函数(正态分布曲 ...