公网远程连接本地socket服务【内网穿透】


1. 配置本地socket服务

Java 服务端demo环境

  • jdk1.8
  • 框架:springboot+maven
  • 开发工具:IDEA

在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服务冲突

在这里插入图片描述

创建java服务端,以接口模式创建,方便外部调用

@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);

     });

    });

}

启动服务,出现以下信息表示启动成功,暴露端口默认:9999

在这里插入图片描述

2. 本地socket服务暴露至公网

将本地服务暴露至公网可访问,我们可以通过cpolar内网穿透来实现,无需公网IP,也无需设置路由器。如果您还未安装cpolar,请参考官网文档——入门指南

2.1 创建隧道映射9999端口

本地安装配置cpolar完成后,在浏览器访问本地9200端口(http://127.0.0.1:9200),登录cpolar web UI管理界面。

点击左侧的隧道管理——创建隧道:

  • 隧道名称:可自定义,注意不要与已有隧道名称重复
  • 协议:tcp
  • 本地地址:9999
  • 端口类型:免费选择随机
  • 地区:选择China VIP

点击创建

在这里插入图片描述

注意:该隧道选择的是临时tcp地址和端口,24小时内会变化,如需固定tcp地址,可升级为专业套餐做tcp地址固定!

2.2 获取公网地址

隧道创建成功后,点击左侧的状态——在线隧道列表,可以查看到刚刚所创建的隧道,已经有生成了相应的公网地址,将其复制下来。

在这里插入图片描述

3. 公网连接本地socket服务端

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

以基于go的socket客户端为例,通过公网连接java socket服务端

  • go版本:1.19
  • 开发工具:VSCODE

通过git下载websocket框架

go get github.com/gorilla/websocket

在这里插入图片描述

创建GO客户端, 注意: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
    }
}

接着启动服务,与服务端连接,出现服务端返回的字样表示连接成功

在这里插入图片描述

客户端在控制台输入信息,点击回车

在这里插入图片描述

服务端接收到且打印出现客户端发送的信息

在这里插入图片描述

在服务端控制台输入消息,按回车

在这里插入图片描述

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

在这里插入图片描述

内外网穿透是指在网络环境中,通过一种技术手段实现将内网中的服务暴露到外网,使外网用户可以访问内网中的服务。在引用\[1\]中的代码中,通过建立一个中间机器,使用公网IP,将客户端安装在内网,实现了简单的转发。转发的原理是,服务端建立一个服务端口,客户端连接到该端口后,服务端再建立一个本地的消息转发端口,然后建立一个客户端连接到想要转发的端口,将该端口传回来的消息发给本地的消息转发端口,最后再将消息发给服务端口,实现了转发的功能。这样就可以实现内外网穿透。在引用\[2\]中的代码中,以远程桌面3389端口为例,实现了简单的转发。在引用\[3\]中的代码中,使用C#编程实现了TCP协议的socket编程,通过绑定IP地址和端口,监听连接请求,实现了服务器的功能。 #### 引用[.reference_title] - *1* *2* [利用socket转发消息实现内网穿透](https://blog.csdn.net/qq_35189120/article/details/111942009)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [C#中Socket通讯(外网通讯,借助花生壳内网穿透)](https://blog.csdn.net/yunhaiC/article/details/121034490)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值