
软件名称:WebSocket(基于TCP协议的双向通信技术)
操作系统支持:跨平台兼容(Windows/macOS/Linux),甚至能嵌入物联网设备!
软件介绍: WebSocket是开发者眼中的"实时通讯特工",能让客户端与服务器像打电话一样直接对话------无需反复"呼喊",数据秒级同步。搭配cpolar内网穿透,连局域网内的监控系统都能远程操控,就像给网络加了个"千里传音"功能!

WebSocket+cpolar:给实时通信装个"跨时空传送门"
-
核心功能:
- 全双工实时传输:"双向车道"比单行道快10倍,聊天、游戏、监控都能丝滑流畅。
- 低延迟轻量级:告别HTTP的反复握手,数据直达不绕路!

WebSocket如何改变世界
- 场景一:远程团队协作噩梦终结者
- 痛点:"跨国会议用Zoom卡成PPT放映厅,白板修改要靠截图接力!"
- 爽点:WebSocket+cpolar让局域网内的共享白板秒变全球实时同步------东京的画笔和纽约的橡皮擦同时开工!
- 场景二:游戏开发者的"千里眼"
- 痛点:"测试服只在公司内网跑,远程调试只能靠截图+电话口述!"
- 爽点:用WebSocket实时传输玩家操作数据,再搭配cpolar穿透------在家就能操控服务器端,BUG无处遁形!
- 场景三:物联网监控的"破壁人"
- 痛点:"工厂传感器数据只能本地看,老板出差时想查?得派人扛电脑去!"
- 爽点:WebSocket+cpolar让摄像头、温湿度传感器等设备实时传输数据到手机------千里之外也能当"监控指挥官"。

cpolar内网穿透技术带来的便利
- 远程办公自由:咖啡厅里用手机连WiFi,就能操控公司局域网内的监控摄像头或游戏服务器。
- 安全无死角:通过动态令牌加密,数据传输像"密室传送"一样安全------外人想偷窥?门都没有!
- 物联网解放者:把家庭NAS、智能家居设备的WebSocket端口穿透后,"远程控制全家桶"一键达成。
总结
WebSocket是实时通信领域的"瑞士军刀",而cpolar则是它的"时空穿梭机"。两者组合能突破局域网限制,让数据传输既快又稳------无论是在线教育、游戏开发还是物联网监控,都能实现真正的"零距离"协作!

实时通信+内网穿透,看功能都强大的组合。安装方法已经准备如下👇:
下面我们就来试试吧!
1. Java 服务端demo环境
- jdk1.8
- 框架:springboot+maven
- 工具IDEA
2. 在pom文件引入第三包封装的netty框架maven坐标
xml
<dependency>
<groupId>io.github.fzdwx</groupId>
<artifactId>sky-http-springboot-starter</artifactId>
<version>0.10.6</version>
</dependency>
注意:pom文件里需注释掉springbootweb启动器,web启动器默认是tomcat服务启动,会和netty服务冲突

3. 创建服务端,以接口模式调用,方便外部调用
ini
@GetMapping("/getConnect")
public void getConnect(HttpServerRequest request){
request.upgradeToWebSocket(ws -> {
ws.mountOpen(h->{
ws.send("连接成功,开始聊天吧!");
});
ws.mountText(s -> {
System.out.println(s);
//对方回复
System.out.println("客户端回复: "+s);
//获取控制台输入的值
Scanner scanner =new Scanner(System.in);
String next = scanner.next();
ws.send(next);
});
});
}
4. 启动服务,出现以下信息表示启动成功,暴露端口默认9999

5. 创建隧道映射内网端口
这里我们用cpolar内网穿透来映射内网端口,它支持http/https/tcp协议,不限制流量,无需公网ip,也不用设置路由器,操作简单。
- cpolar一键安装脚本:(国内用户)
ruby
curl -L https://www.cpolar.com/static/downloads/install-release-cpolar.sh | sudo bash
- 或短链接安装方式:(国外用户)
arduino
curl -sL https://git.io/cpolar | sudo bash
-
查看cpolar版本信息
cpolar version
如果正常显示,则安装成功
- cpolar进行token认证
cpolar官网:www.cpolar.com/
进入cpolar官网,注册一个账号并登录进入后台,点击左侧的验证
,可以查看到token码,复制并执行命令进行认证
cpolar authtoken xxxxxxxxxxxxxxxxxx
- 配置cpolar开机自启动
bash
sudo systemctl enable cpolar
- 守护进程方式,启动cpolar
sql
sudo systemctl start cpolar
- 查看cpolar守护进程状态,如正常为active,则为正常启动状态
lua
sudo systemctl status cpolar
cpolar安装成功后,默认会配置两个默认隧道:一个ssh隧道和一个website隧道,可自行删减或者修改。
接着把本地服务通过cpolar暴露到公网,浏览器访问http://127.0.0.1:9200,登录cpolar web ui 界面,创建一个tcp隧道,指向9999端口

注意:该隧道选择的是临时tcp地址和端口,24小时内会变化,如需固定tcp地址,可升级为专业套餐做tcp地址固定!
6. 查看状态->在线隧道,复制所创建隧道的公网地址加端口号

此时,websocket服务端已经从本地localhost暴露至公网,接着我们创建一个客户端测试公网访问socket服务端连接
7. 以基于go的socket客户端为例,通过公网连接java socket服务端
- go版本:1.19
- 工具:vscode
8. 通过git下载websocket框架
arduino
go get github.com/gorilla/websocket

9. 创建客户端, 注意:Host值为上面复制的隧道公网地址!!
go
package main
import (
"fmt"
"log"
"net/url"
"github.com/gorilla/websocket"
)
func main() {
// 定义服务端的地址
u := url.URL{
Scheme: "ws",
Host: "3.tcp.vip.cpolar.cn:10793", //地址为复制隧道的公网地址
Path: "/eth/getConnect"} //服务端controller 映射地址
// 与服务端建立连接
c, _, err := websocket.DefaultDialer.Dial(u.String(), nil)
if err != nil {
log.Fatal("dial:", err)
}
defer c.Close()
// 阻塞主线程
down := make(chan byte)
// 启动一个线程,读取从服务端发送过来的数据
go func() {
for {
_, message, _ := c.ReadMessage()
fmt.Println("服务端回复:" + string(message))
}
}()
//启动一个线程输入消息
go func() {
for {
var input string
fmt.Scanln(&input)
c.WriteMessage(websocket.TextMessage, []byte(input))
}
}()
for {
<-down
}
}
10. 接着启动服务,与服务端连接,出现服务端返回的字样表示连接成功

11. 客户端在控制台输入信息,回车

12. 服务端出现客户端发送的信息

13. 服务端控制台输入消息,回车

14. 客户端收到服务端回复的消息,连接成功

需要注意,免费使用cpolar所生成的公网地址为随机临时地址,24小时内会发生变化。如果需要长期远程连接,建议为其配置固定的tcp端口地址。即登录cpolar官网后,点击预留,保留一个固定tcp端口地址,然后将其配置到相应的隧道中即可。