内网穿透之http代理服务器

在公网访问内网http服务可以用内网穿透工具,例如frpnps等优秀工具。但我发现这类工具会在服务器启动不止一个端口,对于有些网络审查来说很容易发现在进行内网穿透。因此我想是否可以只在服务器启动一个http服务来完成内网穿透,公网服务只开放一个http服务端口即可。因此我完成了相关代码:点击跳转查看代码

原理如下图所示:

如上图所示,内网客户端和公网服务器只会创建一个websocket连接,很好的伪装了相关数据。而且websocket收发都是分段的,因此对这些分段数据进行加解密也非常容易(我的代码懒得做)。

方式1的示例:

sh 复制代码
# 公网服务器运行程序
go run main.go -s 192.168.1.88:8080
# 内网客户端运行程序
go run main.go -c ws://192.168.1.88:8080
# 此时会使用公网 ip:port 作为http代理使用内网机器访问 https://www.baidu.com/
curl -v -x 192.168.1.88:8080 https://www.baidu.com/

方式2的示例:

sh 复制代码
# 公网服务器运行程序
go run main.go -s 192.168.1.88:8080
# 内网客户端运行程序
go run main.go -c ws://192.168.1.88:8080 -p 172.17.1.88:1080
# 此时会使用公网 ip:port 作为http代理使用内网机器通过 代理172.17.1.88:1080 访问 https://www.baidu.com/
curl -v -x 192.168.1.88:8080 https://www.baidu.com/

我已经验证过使用 git clone https://xxx.git 方式通过公网代理克隆内网仓库代码,完美运行。

相关推荐
小高Baby@5 分钟前
Go语言中面向对象的三大特性之继承的理解
开发语言·后端·golang
小高Baby@5 分钟前
Go语言中面向对象的三大特性之封装的理解
开发语言·后端·golang
£漫步 云端彡33 分钟前
Golang学习历程【第八篇 指针(pointer)】
javascript·学习·golang
小二·1 小时前
Go 语言系统编程与云原生开发实战(第11篇)微服务治理实战:服务注册发现 × 负载均衡 × 全链路压测(生产级落地)
微服务·云原生·golang
£漫步 云端彡2 小时前
Golang学习历程【第十一篇 接口(interface)】
开发语言·学习·golang
chillxiaohan14 小时前
GO学习记录——多文件调用
开发语言·学习·golang
Grassto17 小时前
11 Go Module 缓存机制详解
开发语言·缓存·golang·go·go module
福大大架构师每日一题19 小时前
ollama v0.15.2发布:新增Clawdbot集成指令,全面支持Ollama模型启动!
golang·ollama
参.商.20 小时前
【Day25】26.删除有序数组中的重复项 80.删除有序数组中的重复项II
leetcode·golang
小高Baby@21 小时前
ShouldBind、ShouldBindJson、ShouldBindQuery的区别
后端·golang