位置:首页 > 后端 > java

从0到1实现内网穿透

weizhen 发布:2022-05-27 10:29:49阅读:

什么是:内网穿透

1. 原理

简单而言,我们要实现的效果就是用户访问服务端的54512端口就想是在访问客户的3306端口一样。


客户端注册

最重要的当然是客户端与服务端建立连接(这个连接可以是纯tcp,也可以是http,websocket都行,只要能相互通信即可),客户端需要告诉服务端我想暴露哪些端口,然后服务端就会监听对应数量的端口(这个地方可以优化为服务端只监听一个端口)。

这时候就已经完成了客户端的注册。

用户访问

如果用户现在访问服务端的49875端口,如果想要正确的转发到客户端的9527端口应该怎样做呢?

  1. 用户的请求数据与当前服务端的端口一起发送到客户端

    1. 为什么要发送当前服务端的端口? 因为要告诉客户端当前用户具体要访问的是哪个端口,我们前面返回给客户端端口映射关系。

  1. 客户端接收到请求后,查询端口映射关系,然后连接到对应的9527上去,并发送服务端发送过来的用户的请求数据

    1. 比如说是http请求的话 可能是这样的  GET /XXXX HTTP/1.1 HOST: XXXX  User-Aagent: xxx

  1. 9527根据对应用户请求数据做出响应,然后发送到与客户端建立的连接中

    1. 比如说一个http response `HTTP/1.1 200 OK content-length:xxx \r\n helloworld\r\n`

  1. 最后客户端将9527的响应数据转发到服务端,服务端又转发到用户。

  2. 然后就是重复1~4


可以说是很清楚了,最后项目地址https://github.com/fzdwx/burst

后面可能会考虑出源码从0到1写完一个简版的。


24人点赞 返回栏目 提问 分享一波

小礼物走一波,支持作者

还没有人赞赏,支持一波吧

留言(问题紧急可添加微信 xxl18963067593) 评论仅代表网友个人 留言列表

暂无留言,快来抢沙发吧!

本刊热文
网友在读
手机扫码查看 手机扫码查看