「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

这篇具有很好参考价值的文章主要介绍了「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

💛前情提要💛

本章节是番外篇Socket的相关知识~

接下来我们即将进入一个全新的空间,对代码有一个全新的视角~

以下的内容一定会让你对Socket有一个颠覆性的认识哦!!!

以下内容干货满满,跟上步伐吧~


作者介绍:

🎓 作者: 热爱编程不起眼的小人物🐐
🔎作者的Gitee:代码仓库
📌系列文章&专栏推荐: 《刷题特辑》、 《C语言学习专栏》、《数据结构_初阶》 、《C++轻松学_深度剖析_由0至1》、《Linux - 感受系统美学》

📒我和大家一样都是初次踏入这个美妙的“元”宇宙🌏 希望在输出知识的同时,也能与大家共同进步、无限进步🌟
🌐这里为大家推荐一款很好用的刷题网站呀👉点击跳转



💡本章重点

  • socket的相关引入

  • TCP端口的理解

  • Java通信的应用


🍞一. 配置本地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」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

  • 创建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

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

🍞二. 本地socket服务暴露至公网

💡暴漏公网:

  • 将本地服务暴露至公网可访问,我们可以通过cpolar内网穿透来实现,无需公网IP,也无需设置路由器

cpolar官网:https://www.cpolar.com/

  • cpolar 安装(国内使用)
curl -L https://www.cpolar.com/static/downloads/install-release-cpolar.sh | sudo bash
  • 或 cpolar短链接安装方式:(国外使用)
curl -sL https://git.io/cpolar | sudo bash
  • 查看版本号,有正常显示版本号即为安装成功
cpolar version
  • token认证
    登录cpolar官网后台,点击左侧的验证,查看自己的认证token,之后将token贴在命令行里
cpolar authtoken xxxxxxx

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

  • 简单穿透测试
cpolar http 8080 #按ctrl+c即可退出
  • 向系统添加服务
sudo systemctl enable cpolar
  • 启动cpolar服务
sudo systemctl start cpolar
  • 查看服务状态
sudo systemctl status cpolar

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

🥐Ⅰ. 创建隧道映射9999端口

💡创建隧道:

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

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

    • 隧道名称:可自定义,注意不要与已有隧道名称重复

    • 协议:tcp

    • 本地地址:9999

    • 端口类型:免费选择随机

    • 地区:选择China VIP

点击创建

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

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

🥐Ⅱ. 获取公网地址

💡获取公网地址:

  • 隧道创建成功后,点击左侧的状态,在线隧道列表

  • 即可查看到刚刚所创建的隧道,已经有生成了相应的公网地址,并将其复制下来

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

🍞三. 公网连接本地socket服务端

💡公网连接本地socket服务端:

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

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

    • go版本:1.19

    • 开发工具:VSCODE

通过git下载websocket框架:

go get github.com/gorilla/websocket

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

创建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
    }
}
  • 接着启动服务,与服务端连接,出现服务端返回的字样表示连接成功

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

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

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

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

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

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

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

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

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

🍞四. 配置固定TCP端口地址

💡配置固定TCP端口地址:

  • 由于以上教程使用的随机端口,虽然可以永久免费使用,但是该地址会在24小时内随机变化

  • 这对于经常访问的用户,或者生产环境的服务来说很不方便。为此,我们可以为其配置一个永久固定的公网TCP地址来进行远程。

注意:需要将cpolar套餐升级至专业套餐或以上。

🥐Ⅰ. 保留一个固定TCP地址

登录cpolar官网后台,点击左侧的预留,找到保留的TCP地址:

  • 地区:选择China VIP

  • 描述:即备注,可自定义填写,本例为socket

点击保留,并固定TCP地址保留成功后,系统会生成相应的公网地址+固定端口号,将其复制下来

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

🥐Ⅱ. 配置固定TCP端口地址

  • 访问http://127.0.0.1:9200/登录cpolar web UI管理界面,

  • 点击左侧仪表盘的隧道管理——隧道列表,找到需要配置的隧道,点击右侧的编辑

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

修改隧道信息,配置固定TCP端口地址:

  • 端口类型:改为选择固定TCP端口

  • 预留的TCP地址:填写刚刚保留成功的固定TCP端口地址

  • 点击更新

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

  • 提示更新隧道成功,点击左侧仪表盘的状态——在线隧道列表

  • 即可看到公网地址已经更新为固定TCP端口地址,将其复制下来

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

🍞五. 替换go客户端里的地址

💡替换go客户端里的地址:

「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯

类型:改为选择固定TCP端口

  • 预留的TCP地址:填写刚刚保留成功的固定TCP端口地址

  • 点击更新

  • 提示更新隧道成功,点击左侧仪表盘的状态——在线隧道列表,可以看到公网地址已经更新为固定TCP端口地址,将其复制下来

  • 即可完成

🫓总结

综上,我们基本了解了Java中的 “Socket实现客户端和服务端通讯” 🍭 的知识啦~~

恭喜你的内功又双叒叕得到了提高!!!

感谢你们的阅读😆

后续还会继续更新💓,欢迎持续关注📌哟~

💫如果有错误❌,欢迎指正呀💫

✨如果觉得收获满满,可以点点赞👍支持一下哟~✨
「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯文章来源地址https://www.toymoban.com/news/detail-415096.html

到了这里,关于「Java」Socket实现简单的客户端和服务端通讯 | 公网环境通讯的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Java】网络编程与Socket套接字、UDP编程和TCP编程实现客户端和服务端通信

    为什么需要网络编程? 现在网络普及程序越来越高,网络上保存着我们日常生活中需要的各种资源,使用程序通过网络来获取这些资源的过程就需要网络编程来实现。 什么是网络编程? 网络编程,指网络上的主机,通过不同的进程以程序的方式实现网络通信(网络数据传输)

    2024年02月17日
    浏览(51)
  • 使用socket.io简单实现多客户端可编辑表格

    之前看了B站小野森森老师的可编辑表格的视频深受启发,今天使用React简单实现一下。 当处于编辑状态的时候,自己和其他人可以看到; 编辑内容后,自己及其他人可以同步看到修改后的内容; 后端服务,使用socket.io起一个后端服务,用于监听连接和发送数据; 前端准备:

    2024年02月06日
    浏览(35)
  • 基于C# Socket实现的简单的Redis客户端

         Redis 是一款强大的高性能键值存储数据库,也是目前 NOSQL 中 最流行 比较流行的一款数据库,它在广泛的应用场景中扮演着至关重要的角色,包括但不限于缓存、消息队列、会话存储等。在本文中,我们将介绍如何基于 C# Socket 来实现一个简单的Redis客户端类 RedisClien

    2024年02月05日
    浏览(38)
  • Java【网络编程2】使用 TCP 的 Socket API 实现客户端服务器通信(保姆级教学, 附代码)

    📕各位读者好, 我是小陈, 这是我的个人主页 📗小陈还在持续努力学习编程, 努力通过博客输出所学知识 📘如果本篇对你有帮助, 烦请点赞关注支持一波, 感激不尽 📙 希望我的专栏能够帮助到你: JavaSE基础: 基础语法, 类和对象, 封装继承多态, 接口, 综合小练习图书管理系统

    2024年02月05日
    浏览(44)
  • 因项目只做socket客户端,不想用workerman或者swoole框架,简单实现ws PHP客户端

    docs/Client.md · master · mirrors / Textalk / websocket-php · GitCode

    2024年02月13日
    浏览(43)
  • Socket实例,实现多个客户端连接同一个服务端代码&TCP网络编程 ServerSocket和Socket实现多客户端聊天

    Java socket(套接字)通常也称作\\\"套接字\\\",用于描述ip地址和端口,是一个通信链的句柄。应用程序通常通过\\\"套接字\\\"向网络发出请求或者应答网络请求。 使用socket实现多个客户端和同一客户端通讯;首先客户端连接服务端发送一条消息,服务端接收到消息后进行处理,完成后再

    2024年02月12日
    浏览(49)
  • 【网络原理】使用Java基于UDP实现简单客户端与服务器通信

    我们用Java实现UDP数据报套接字编程,需要借用以下API来实现 网络编程, 本质上是要操作网卡. 但是网卡不方便直接操作. 在操作系统内核中, 使用了一种特殊的叫做 “socket” 这样的文件来抽象表示网卡. 因此进行网络通信, 势必需要先有一个 socket 对象. DatagramSocket 是UDP Socket,

    2024年03月11日
    浏览(47)
  • Java分别用BIO、NIO实现简单的客户端服务器通信

    前言: Java I/O模型发展以及Netty网络模型的设计思想 Java BIO是Java平台上的BIO(Blocking I/O)模型,是Java中用于实现同步阻塞网络编程的一种方式。 在Java中,使用BIO模型需要通过Socket和ServerSocket类来完成网络连接和数据传输,但是由于BIO是同步阻塞的,所以会导致线程阻塞和资

    2024年02月09日
    浏览(30)
  • Socket实现服务器和客户端(手把手教会)

    😎 作者介绍:我是程序员行者孙,一个热爱分享技术的制能工人。计算机本硕,人工制能研究生。公众号:AI Sun,视频号:AI-行者Sun 🎈 本文专栏:本文收录于《网络编程实战》系列专栏,相信一份耕耘一份收获,我会手把手教分享网络编程实战内容,届时可以拳打字节,

    2024年04月12日
    浏览(36)
  • java socket Server TCP服务端向指定客户端发送消息;可查看、断开指定连接的客户端;以及设置客户端最大可连接数量。

    首先需要知道java里如何创建一个Socket服务器端。 提示:注意server.accept()方法调用会阻塞,只有新的客户端连接后才返回一个新的socket对象。如果一直未连接那么会一直处于阻塞状态 了解了如何创建一个socket服务器端后。那么如何实现给指定的连接客户端发送消息呢?首先我

    2024年02月11日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包