ssh端口转发-记录

1、本地转发


基本命令:

ssh -L local_port:target_ip:target_port username@tunnel_host_ip -N -f -p tunnel_host_port

参数说明:

  • -L:转发本地端口。
  • -N:不发送任何命令,只用来建立连接。没有这个参数,会在 SSH 服务器打开一个 Shell。
  • -f:将 SSH 连接放到后台。没有这个参数,暂时不用 SSH 连接时,终端会失去响应。
  • -p:代理主机tunnel_host_ip SSH登录的端口,一般是22。
  • tunnel_host_ip:代理(隧道)主机的ip。
  • username:SSH登录tunnel_host_ip 的用户名。
  • local_port:本地端口。
  • target_ip:要转发的目标主机ip。
  • target_port :要转发的目标主机端口。

实现作用:
        当本地pc上的程序访问本地的local_port端口时,相当于访问target_ip主机的target_port端口,这个转发是由tunnel_host_ip主机实现,这个ssh验证使用主机需要tunnel_host_ip、username和 -p登录的端口(当然还有密码)。要求,本地pc能直接访问tunnel_host_ip主机,并且tunnel_host_ip主机能直接访问target_ip主机。

2、远程转发


基本命令:

ssh -C -R remote_port:target_ip:target_port username@remote_host_ip -N -f -p remote_host_port

参数说明:

  • -C:传输数据压缩。
  • -R:远程端口转发。
  • -N:不发送任何命令,只用来建立连接。没有这个参数,会在 SSH 服务器打开一个 Shell。
  • -f:将 SSH 连接放到后台。没有这个参数,暂时不用 SSH 连接时,终端会失去响应。
  • -p:代理主机remote_host_ip SSH登录的端口,一般是22。
  • remote_host_ip:代理(隧道)主机的ip。
  • username:SSH登录tunnel_host_ip 的用户名。
  • remote_port:远程端口。
  • target_ip:要转发的目标主机ip。
  • target_port :要转发的目标主机端口。

实现作用:
        当程序访问remote_host_ip(外网) 的 remote_port 端口时,相当于访问target_ip(内网)主机的target_port端口,这个转发是由remote_host_ip(外网)主机与发起这个ssh请求的主机(内网主机)实现,这个ssh验证使用主机需要remote_host_ip、username和 -p登录的端口(当然还有密码)。要求,发起这个ssh请求的主机能直接访问remote_host_ip 主机,并且发起这个ssh请求的主机能直接访问target_ip主机。

参考

https://wangdoc.com/ssh/port-forwarding

  • 6
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要通过C语言和libssh.so库实现SSH端口转发功能,可以分为以下几个步骤: 1. 初始化SSH会话:使用ssh_new函数创建SSH会话对象,并设置相关参数,如连接超时时间、认证方式等。 2. 建立SSH连接:使用ssh_connect函数连接远程SSH服务器,并进行身份认证,可使用用户名/密码、公钥/私钥等方式进行认证。 3. 创建SSH通道:使用ssh_channel_new函数创建SSH通道对象,并设置相关参数,如通道类型、缓冲区大小等。 4. 监听本地端口:使用ssh_channel_listen_forward函数监听本地端口,并将流量转发到远程主机的指定端口。 5. 接受远程连接:使用ssh_channel_accept_forward函数接受来自远程主机的连接请求,并将流量转发到本地端口。 6. 关闭SSH会话:使用ssh_disconnect函数关闭SSH连接,并释放相关资源。 下面是一个简单的C语言程序示例,实现了SSH端口转发的功能: ``` #include <libssh/libssh.h> int main(int argc, char *argv[]) { ssh_session session; ssh_channel channel; // 初始化SSH会话 session = ssh_new(); ssh_options_set(session, SSH_OPTIONS_HOST, "remote_host"); ssh_options_set(session, SSH_OPTIONS_USER, "username"); ssh_connect(session); // 建立SSH连接 ssh_userauth_password(session, NULL, "password"); // 创建SSH通道 channel = ssh_channel_new(session); ssh_channel_open_forward(channel, "localhost", 8080, "remote_host", 80); // 监听本地端口 ssh_channel_listen_forward(channel, "localhost", 8080); // 接受远程连接 ssh_channel_accept_forward(channel, 5000); // 关闭SSH会话 ssh_disconnect(session); ssh_free(session); return 0; } ``` 需要注意的是,上述示例代码仅仅是一个简单的示例,实际应用中还需要进行错误处理、日志记录等相关操作。同时,还需要注意SSH端口转发可能存在的安全风险,建议仅在必要情况下使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值