不用服务器也能让本地 Websocket 跑遍全网?cpolar帮我搞定了

不用服务器也能让本地 Websocket 跑遍全网?cpolar帮我搞定了

文章目录

前言

cpolar 是一款内网穿透工具,能把本地服务映射到公网,适用开发者调试实时通信应用、多端联调等场景,优点是操作简单,无需公网 IP 和复杂配置。

用下来发现,它启动快、隧道加密靠谱,但免费版公网地址 24 小时会变,长期用得考虑固定地址,不过临时测试完全够用。

本地 Websocket 服务只能在局域网内用挺麻烦,比如和异地同事联调时,得让对方连进同一局域网,或者费劲部署到云服务器,费时又费钱。

而 cpolar 和 Websocket 结合就方便多了,一行命令就能让本地服务暴露到公网,不管本地 IP 怎么变,公网访问都稳定,省了部署服务器的功夫,调试效率高多了。

下面我们就来试试吧!

1. Java 服务端demo环境
  • jdk1.8
  • 框架:springboot+maven
  • 工具IDEA
2. 在pom文件引入第三包封装的netty框架maven坐标
<dependency><groupId>io.github.fzdwx</groupId><artifactId>sky-http-springboot-starter</artifactId><version>0.10.6</version></dependency>
注意:pom文件里需注释掉springbootweb启动器,web启动器默认是tomcat服务启动,会和netty服务冲突
20221220152746
3. 创建服务端,以接口模式调用,方便外部调用
@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
20221220152808
5. 创建隧道映射内网端口

这里我们用cpolar内网穿透来映射内网端口,它支持http/https/tcp协议,不限制流量,无需公网ip,也不用设置路由器,操作简单。

  • cpolar一键安装脚本:(国内用户)
curl -L https://www.cpolar.com/static/downloads/install-release-cpolar.sh |sudobash
  • 或短链接安装方式:(国外用户)
curl -sL https://git.io/cpolar |sudobash
  • 查看cpolar版本信息
cpolar version 

如果正常显示,则安装成功

  • cpolar进行token认证
cpolar官网:https://www.cpolar.com/

进入cpolar官网,注册一个账号并登录进入后台,点击左侧的验证,可以查看到token码,复制并执行命令进行认证

cpolar authtoken xxxxxxxxxxxxxxxxxx 
  • 配置cpolar开机自启动
sudo systemctl enable cpolar 
  • 守护进程方式,启动cpolar
sudo systemctl start cpolar 
  • 查看cpolar守护进程状态,如正常为active,则为正常启动状态
sudo systemctl status cpolar 

cpolar安装成功后,默认会配置两个默认隧道:一个ssh隧道和一个website隧道,可自行删减或者修改。

接着把本地服务通过cpolar暴露到公网,浏览器访问http://127.0.0.1:9200,登录cpolar web ui 界面,创建一个tcp隧道,指向9999端口

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

此时,websocket服务端已经从本地localhost暴露至公网,接着我们创建一个客户端测试公网访问socket服务端连接

7. 以基于go的socket客户端为例,通过公网连接java socket服务端
  • go版本:1.19
  • 工具:vscode
8. 通过git下载websocket框架
go get github.com/gorilla/websocket 
20221220152904
9. 创建客户端, 注意:Host值为上面复制的隧道公网地址!!
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. 接着启动服务,与服务端连接,出现服务端返回的字样表示连接成功
20221220152924
11. 客户端在控制台输入信息,回车
20221220152933
12. 服务端出现客户端发送的信息
20221220152943
13. 服务端控制台输入消息,回车
20221220152951
14. 客户端收到服务端回复的消息,连接成功

需要注意,免费使用cpolar所生成的公网地址为随机临时地址,24小时内会发生变化。如果需要长期远程连接,建议为其配置固定的tcp端口地址。即登录cpolar官网后,点击预留,保留一个固定tcp端口地址,然后将其配置到相应的隧道中即可。
总之,cpolar 让本地 Websocket 服务轻松实现公网访问,简化了调试和联调流程,对开发者来说是个实用工具。

cpolar官网-安全的内网穿透工具 | 无需公网ip | 远程访问 | 搭建网站

Read more

Spring MVC请求处理流程源码分析与DispatcherServlet核心逻辑

Spring MVC请求处理流程源码分析与DispatcherServlet核心逻辑

目录 🎯 先说说我遇到过的真实问题 ✨ 摘要 1. 从Tomcat到DispatcherServlet:请求的"奇幻漂流" 1.1 请求是怎么到你Controller的? 1.2 DispatcherServlet的初始化:不是你想的那样简单 2. 请求处理九大步:DispatcherServlet的"工作流程" 2.1 doDispatch方法:Spring MVC的心脏 2.2 九步流程详解:每个步骤都有坑 🚨 步骤1:Multipart检查 🚨 步骤2:获取Handler 3. HandlerMapping:请求的"导航系统" 3.1 四种HandlerMapping的区别 3.2 RequestMappingHandlerMapping的匹配算法 3.3 路径匹配的性能优化

By Ne0inhk
数字身份的通行证:深入解析单点登录(SSO)的架构与艺术

数字身份的通行证:深入解析单点登录(SSO)的架构与艺术

文章目录 * 概述 * 一、什么是单点登录(SSO)? * 二、SSO 的核心价值:为何它如此重要? * 三、SSO 的基本工作原理:一次认证,处处通行 * 场景一:首次登录应用 A * 场景二:访问应用 B(无感登录) * 四、SSO 的通用语言:常见协议与标准 * 五、SSO 架构的两种主流形态 * 1. **中心化 SSO** * 2. **联邦身份** * 六、安全:SSO 的生命线 * 七、典型应用场景:SSO 在哪里发光? * 八、快速上手:从理论到实践 * 九、常见误区澄清 * 总结 概述 在数字世界日益碎片化的今天,我们每个人都在无数应用和服务之间穿梭,

By Ne0inhk
Rust异步编程实战:构建高性能网络应用

Rust异步编程实战:构建高性能网络应用

Rust异步编程实战:构建高性能网络应用 一、异步编程概述 1.1 同步vs异步的区别 💡在传统的同步编程中,代码按照顺序执行,每个操作必须等待前一个完成才能继续。例如,发送网络请求时,主线程会阻塞直到响应返回,这种方式简单直观,但在高并发场景下效率低下,因为大量线程会因阻塞而闲置。 异步编程则允许代码在等待操作完成时继续执行其他任务。当一个异步操作开始后,程序会立即返回并继续处理下一个任务,直到该操作完成后通过回调或事件通知继续执行后续代码。这种方式显著提高了CPU利用率和系统的并发处理能力。 1.2 Rust异步编程的演进 Rust的异步编程经历了几个重要阶段: * 早期阶段:依赖futures库提供基础的Future和Executor支持,但语法冗长且难以使用。 * 2018 Edition:引入了async/await语法糖的实验版本,简化了异步代码的编写。 * 2021 Edition:async/await正式稳定,成为Rust异步编程的标准范式。 * 生态成熟:Tokio、async-std等异步运行时库的发展,以及大量异步IO库的出现,使Rus

By Ne0inhk

Flutter 三方库 inject_annotation 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、严谨的编译期依赖注入架构实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 inject_annotation 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、严谨的编译期依赖注入架构实战 在鸿蒙(OpenHarmony)系统开发大型、复杂的企业级应用时,如何优雅地解耦各个业务模块?传统的构造函数注入往往会导致代码冗长且难以维护。inject_annotation 为鸿蒙开发者提供了一套基于编译期生成的、零反射的依赖注入(Dependency Injection)方案。本文将带您深入实战其在鸿蒙生态中的应用。 前言 什么是依赖注入?它是一种控制反转(IoC)的实现方式,旨在将对象的创建与使用分离。与运行时反射注入不同,inject_annotation 借鉴了 Java 端 Dagger 的设计思想,在编译阶段就生成了所有的注入代码。在注重性能和确定性的鸿蒙系统开发中,这种“预编译”的 DI 方案能大幅降低运行期开销,并显著提升代码的健壮性。 一、

By Ne0inhk