爆款云主机2核4G限时秒杀,88元/年起!
查看详情

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
热门活动
  • 618智算钜惠季 爆款云主机2核4G限时秒杀,88元/年起!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 首保服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      初始JavaEE篇 —— 网络编程(2):了解套接字,从0到1实现回显服务器

      首页 知识中心 云端实践 文章详情页

      初始JavaEE篇 —— 网络编程(2):了解套接字,从0到1实现回显服务器

      2025-02-12 09:25:49 阅读次数:11

      Socket,UDP,客户端,接字,服务器

      网络基础知识   在一篇文章中,我们了解了基础的网络知识,网络的出现就是为了不同机器之间进行通信从而实现资源共享。现如今我们使用网络进行的一系列操作,打游戏、网上购物、网上聊天等都是客户端与服务器之间通信,准确的来说是多个客户端之间通过服务器这个平台来实现通信。而今天我们就是要来实现一个最简单的服务器与客户端。在此之前还得了解一些基本概念。

       TCP 与 UDP

      上文了解了 TCP/IP 五层协议的基本分层,在以后的日常开发中,写的一些应用程序都是工作在应用层,而应用层是基于传输层的,我们也是需要了解传输层的传输协议的,主要是两个协议:TCP协议 与 UDP 协议。 

      TCP 是 有连接、可靠传输、面向字节流、全双工。

      UDP 是 无连接、不可靠传输、面向数据报、全双工。

       

      连接:是指通信双方是否会保存对方的信息。有连接就说明,通信的双方会保存对方的信息。

      可靠传输:由于数据在经过封装之后,是通过网卡将二进制的数据传输给另一方的,这里的二进制是通过电信号或者光信号传播的,而这种传播方式肯定是会收到外界的影响,例如,太阳爆发耀斑等情况就会影响数据的传输。因此数据传输的过程中可能会失败,如果传输失败之后,有提醒重新传输的话,这就是可靠传输,反之,传输之后不管不顾了,这就是不可靠传输。

      面向字节流与面向数据报是指两者的数据传输的方式不一样,虽然最终通过网卡出去的数据都是二进制的,但是在通过传输层时,会根据协议的不同,而选择不同的方式。使用UDP传输时,就需要将数据封装成数据包的形式继续传给下一层。

      全双工:是指数据既可以从一方传向另一方,也可以从另一方传向这一方,也就是和车流量一样,既有从左到右的车流,也有从右到左的车流。与之相反的一个名词是:半双工,这个就和管中的水流一样,只能从一方流向另一方,而不能从同时有两个方向的水流。

      了解了TCP 与 UDP 的基本点之后,还需要了解 JVM对于操作系统提供的API封装后的结果,毕竟我们通过Java代码来编写网络编程时,是直接使用Java标准库中提供的类。

      Socket套接字

      Socket套接字,是由操作系统提供用于网络通信的技术,是基于TCP/IP协议的网络通信的基本操作单元。 基于Socket套接字的网络程序开发就是网络编程。而经过JVM封装之后,就主要是针对 TCP 和 UDP 的。

      UDP

      java中使用UDP协议通信,主要基于DatagramSocket 类来创建数据报套接字,并使用
      DatagramPacket作为发送或接收的UDP数据报。

      因为操作系统为了方面更好的管理系统资源(包括硬件资源),所以操作系统采用了文件管理的方式来管理这些资源,这也就意味着某个应用程序去使用这些资源时,就和使用文件资源没什么区别了,也就是打开文件、使用文件、关闭文件。因此网卡资源的使用也是如此。

      1、打开网卡资源

      2、进行读写操作

      3、关闭网卡资源

      下面就来学习相关方法:

      DatagramSocket 是UDP Socket,用于发送和接收UDP数据报。

      构造方法 说明
      DatagramSocket() 创建一个UDP数据报套接字的Socket,绑定到本机任意一个随机端口 (一般用于客户端)
      DatagramSocket(int port) 创建一个UDP数据报套接字的Socket,绑定到本机指定的端口 (一般用于服务器)
      普通方法 说明
      void receive(DatagramPacket p) 从此套接字接收数据报(如果没有接收到数据报,该方法会阻塞等待)
      void send(DatagramPacket p) 从此套接字发送数据报包(不会阻塞等待,直接发送)
      void close() 关闭此数据报套接字

      这里的数据报套接字我们可以简单的理解为网卡资源,receive方法就是通过网卡接收数据,send方法就是通过网卡发送数据。 构造方法是在打开网卡资源,close方法就是在关闭网卡资源。

      DatagramPacket是UDP Socket发送和接收的数据报。

      注意区分上述两个概念:DatagramSocket 是用来传送与接收数据报的,而DatagramPacket 是数据报本身的一层封装,简单理解就是数据报本身。生活中的例子,就是DatagramSocket 是属于快递站,而DatagramPacket 是属于包裹。包裹要通过快递站的分拣传递出去。

      构造方法 说明
      DatagramPacket(byte[] buf, int length) 构造一个DatagramPacket以用来接收数据报,接收的数据保存在字节数组(第一个参数buf)中,接收指定长度 (第二个参数length)
      DatagramPacket(byte[] buf, int offset, int length,SocketAddress address)  构造一个DatagramPacket以用来发送数据报,发送的数据为字节数组(第一个参数buf)中,从offset到指定长
      度(第二个参数length)。address指定目的主机的IP
      和端口号
      具体方法 说明
      InetAddress getAddress() 从接收的数据报中,获取发送端主机IP地址;或从发送的数据报中,获取接收端主机IP地址
      int getPort() 从接收的数据报中,获取发送端主机的端口号;或从
      发送的数据报中,获取接收端主机端口号
      byte[] getData() 获取数据报中的数据

       由于UDP是无连接的,因此构造UDP发送的数据报时,需要传入 SocketAddress ,该对象可以使用 InetSocketAddresS 来创建。即 InetSocketAddress 是 SocketAddress 的子类。

      构造方法 说明
      InetSocketAddress(InetAddress addr, int port) 创建一个Socket地址,包含IP地址和端口号

      先来理解服务器与客户端这个两个名词的含义: 

      举个例子:我们去学校食堂吃饭时,可能某个窗口的饭菜比较好吃,那么我们下一次或者以后都有可能会去这个窗口吃饭,而这个窗口肯定是一直在这个食堂的某个固定地点的,而这个窗口所服务的学生不是固定的,每个学生去吃饭时,肯定也是随机选择的座位坐下来吃饭。

      针对上面的情况,食堂的窗口就是服务器,吃饭的学生就是客户端,客户端会给服务器提供请求(我们会把吃的菜告诉食堂阿姨),服务器会给客户端提供响应(食堂阿姨就会给我们打对应的菜)。因为服务器(食堂窗口)是需要给多个客户端提供响应,如果这个服务器的端口老是发生变化(窗口老是发生变化),那肯定是不方便客户端去访问的,因此服务器的IP与端口都是在一段时间内固定的,而客户端的端口(学生在吃饭找的座位)肯定是随机的,如果某个学生没在这里,但是他占了一个位置,那么肯定是不合理的,同样某个客户端没有启动进程访问服务器时,一直把端口号给踹在怀里肯定也是会对别的进程造成影响的(端口号是有限的)。

      有了以上信息,我们就可以来写一个最简单服务器:回显服务器(接收到的请求就是响应,即接收的请求是什么,服务器返回的响应也就是什么,类似于鹦鹉学舌)。

      服务器的处理逻辑:1、接收请求并解析;2、根据请求计算响应;3、将相应发送给响应的客户端;4、打印日志。

      public class UdpEchoServer {
          // 创建网卡资源
          DatagramSocket socket = null;
          public UdpEchoServer(int port) throws SocketException {
              // 指定本机的一个固定端口号为服务器的端口号
              socket = new DatagramSocket(port);
          }
          // 启动服务器方法
          public void start() throws IOException {
              // 由于服务器是7*24小时的工作制,因此得死循环
              System.out.println("服务器启动成功~");
              while (true) {
                  // 1、网卡接收请求并解析
                  // 创建一个数据报来接收请求的具体内容
                  // 数据报其实就是一个用来存储数据的包裹:字节数组+长度组成
                  DatagramPacket requestPacket = new DatagramPacket(new byte[4096], 4096);
                  socket.receive(requestPacket); // 将得到的数据存储在数据报的字节数组中
                  // 将数据报中的内容转成字符串为后续处理做准备
                  String request = new String(requestPacket.getData(), 0, requestPacket.getLength()); // 数据的有效长度
                  // 2、根据请求计算响应
                  String response = process(request);
                  // 3、将响应返回给客户端
                  // 也是通过数据报的形式
                  // 由于UDP是无连接的,因此我们得手动去设置发送的IP与端口号
                  DatagramPacket responsePacket = new DatagramPacket(response.getBytes(), 0, response.getBytes().length,
                          requestPacket.getAddress(), requestPacket.getPort());
                  socket.send(responsePacket);
                  // 4、打印日志:客户端IP、客户端端口号、请求、响应
                  System.out.printf("[%s %d]  request:%s  response:%s\n", requestPacket.getAddress(),
                          requestPacket.getPort(), request, response);
              }
          }
      
          // 后续如果要修改服务器的功能,就只需要重载process方法即可
          private String process(String request) {
              return request; // 回显服务器的功能
          }
      
          public static void main(String[] args) throws IOException {
              // 创建一个服务器实例并启动服务器
              UdpEchoServer server = new UdpEchoServer(9090);
              server.start();
          }
      }
      

      有了服务器之后,就可以来创建客户端程序了。

      public class UdpEchoClient {
          DatagramSocket socket = null;
          // UDP是不连接,因此客户端得保存对应服务器的IP与端口号
          private String serverIP = null;
          private int serverPort = 0;
      
          // 指定需要访问的服务器IP与端口号
          public UdpEchoClient(String serverIP, int serverPort) {
              this.serverIP = serverIP;
              this.serverPort = serverPort;
          }
      
          public void start() throws IOException {
              System.out.println("客户端启动成功(exit退出)~");
              // 创建网卡资源
              socket = new DatagramSocket();
              while (true) {
                  // 1、开始接收用户的输入
                  Scanner scanner = new Scanner(System.in);
                  String request = scanner.nextLine();
                  if (request.equals("exit")) {
                      socket.close(); // 释放网卡资源
                      System.out.println("客户端成功退出~")
                      break;
                  }
                  // 2、将输入数据打包成数据报 (指定服务器IP与端口号)
                  DatagramPacket requestPacket = new DatagramPacket(request.getBytes(), 0 ,request.getBytes().length
                  , InetAddress.getByName(serverIP), serverPort);
                  // 3、然后再给到服务器
                  socket.send(requestPacket);
                  // 4、接收服务器的响应
                  DatagramPacket responsePacket = new DatagramPacket(new byte[4096], 4096);
                  socket.receive(responsePacket);
                  // 5、处理响应:打印响应的结果
                  String response = new String(responsePacket.getData(), 0, responsePacket.getLength()); // 有效的长度
                  System.out.println(response);
              }
          }
      
          public static void main(String[] args) throws IOException {
              // 指定对应服务器的IP与端口号
              UdpEchoClient client = new UdpEchoClient("127.0.0.1", 9090);
              client.start();
          }
      }
      

      注意:127.0.0.1 这就是代指当前机器的IP。 

      运行结果:

      客户端:

      初始JavaEE篇 —— 网络编程(2):了解套接字,从0到1实现回显服务器

      服务器:

      初始JavaEE篇 —— 网络编程(2):了解套接字,从0到1实现回显服务器

      由上图可知,客户端的运行与否和服务器没什么关系,服务器在正常运行的情况下会一直记录客户端的访问信息。 

      下面就来使用另外一种协议来实现回显服务器:

      TCP

      ServerSocket 是创建TCP的服务器Socket的APl。

      ServerSocket :

      构造方法 说明
      ServerSocket(int port) 创建一个服务器流套接字Socket,并绑定到指定端口
      具体方法 说明
      Socket accept() 开始监听指定端口(创建时绑定的端口),有客户端
      连接后,返回一个服务端Socket对象,并基于该
      Socket建立与客户端的连接,否则阻塞等待
      void close() 关闭此套接字

      Socket:

      Socket是客户端Socket,或服务器中接收到客户端建立连接(accept方法)的请求后,返回的服务器Socket。不管是客户端还是服务器Socket,都是双方建立连接以后,保存的对端信息,及用来与对方收发数据的。

      构造方法 说明
      Socket(String host, int port) 创建一个客户端流套接字Socket,并与对应IP的主机上,对应端口的进程建立连接

       这里的构造方法有很多,但是常用的就是通过 String类型的host 来建立连接的。

      具体方法 说明
      InetAddress getlnetAddress() 返回套接字所连接的地址(对端)
      int getPort() 返回套接字所连接的端口号(对端)
      InputStream getlnputStream() 返回此套接字的输入流
      OutputStream getOutputStream() 返回此套接字的输出流

      对端:这个概念是相对的,站在服务器的角度,对端是指客户端;站在客户端的角度,对端指的是服务器。当然,也是可以获取本地程序的地址和端口号的, 使用的是 getLocalPort ,站在服务器的角度,获取的就是服务器自己所在端口。

      这里的ServerSocket 可以理解为网卡资源,而Socket 就是保存TCP连接双方的连接。服务器的连接有很多个,因此我们需要为其申请网卡资源来随时获取新的连接。而客户端只需要和服务器连接即可,因此只需要去尝试申请对应的IP地址与端口号进行连接即可。

      总体的实现思路还是和上面的UDP差不多,但是具体的实现方式有不同。

      服务器:

      public class TcpEchoServer {
          private ServerSocket serverSocket;
      
          public TcpEchoServer(int port) throws IOException {
              serverSocket = new ServerSocket(port);
          }
      
          public void start() throws IOException {
              System.out.println("服务器启动成功~");
              while (true) {
                  System.out.println("等待客户端连接...");
                  Socket socket = serverSocket.accept();
                  System.out.println("客户端连接成功:" + socket.getInetAddress() + ":" + socket.getPort());
                  
                  // 处理客户端连接,进入通信过程
                  handleClient(socket);
              }
          }
      
          private void handleClient(Socket socket) throws IOException {
              try (InputStream inputStream = socket.getInputStream();
                   OutputStream outputStream = socket.getOutputStream()) {
      
                  while (true) {
                      byte[] buffer = new byte[4096];
                      int len = 0;
      
                      StringBuilder sb = new StringBuilder();
                      // 循环读取客户端请求并响应
                      while ((len = inputStream.read(buffer)) != -1) {
                          sb.append(new String(buffer, 0, len));
                          if (sb.toString().contains("\n")) {
                              // 检测到换行符,认为请求结束
                              break;
                          }
                      }
                      String request = sb.toString();
      
                      // 根据请求计算响应
                      String response = process(request);
      
                      // 先判断连接是否终止了
                      if (socket.isClosed()) {
                          return;
                      }
                      // 将响应返回给客户端
                      outputStream.write(response.getBytes());
                      outputStream.flush(); // 刷新缓冲区
                  }
              } finally {
                  socket.close();
                  System.out.println("客户端已断开连接");
              }
          }
      
          private String process(String request) {
              return request+"\n";
          }
      
          public static void main(String[] args) throws IOException {
              TcpEchoServer server = new TcpEchoServer(9090);
              server.start();
          }
      }
      

      客户端:

      public class TcpEchoClient {
          private String serverIp;
          private int serverPort;
      
          public TcpEchoClient(String serverIp, int serverPort) {
              this.serverIp = serverIp;
              this.serverPort = serverPort;
          }
      
          public void start() throws IOException {
              try (Socket socket = new Socket(serverIp, serverPort);
                   OutputStream outputStream = socket.getOutputStream();
                   InputStream inputStream = socket.getInputStream();
                   Scanner scanner = new Scanner(System.in)) {
      
                  System.out.println("客户端连接服务器成功~");
      
                  // 循环发送请求并接收响应
                  while (true) {
                      System.out.print("输入请求数据(exit退出): ");
                      // 加上换行符,让服务器在读取数据时,知道这个是结束的标志
                      String request = scanner.nextLine()+"\n";
      
                      if (request.equals("exit\n")) { // 因为手动加上了换行符,因此判断也要加上
                          System.out.println("客户端请求断开连接");
                          break;
                      }
      
                      // 发送请求数据
                      outputStream.write(request.getBytes());
                      outputStream.flush(); // 刷新缓冲区,更好地让数据发送
      
                      // 接收服务器响应
                      byte[] buffer = new byte[4096];
                      StringBuilder responseBuilder = new StringBuilder();
                      int len = 0;
                      
                      // 使用while循环读取直到服务器停止发送
                      while ((len = inputStream.read(buffer)) != -1) {
                          responseBuilder.append(new String(buffer, 0, len));
                          if (responseBuilder.toString().contains("\n")) { // 检测到换行符,认为响应完整
                              break;
                          }
                      }
                      
                      // 打印完整的响应
                      String response = responseBuilder.toString();
                      System.out.print("接收到服务器响应: " + response);
                  }
              }
          }
      
          public static void main(String[] args) throws IOException {
              TcpEchoClient client = new TcpEchoClient("127.0.0.1", 9090);
              client.start();
          }
      }
      

      注意:

      1、 因为TCP是字节流,因此我们使用的是前面文件IO操作的字节流来进行发送与读取数据。但方式略微不同,我们需使用连接获取字节输入流与字节输出流。

      2、由于这里的输入输出流是建立在连接之上的,我们不知道什么时候输入与输出结束,因此我们得手动地去设置结束标志或者使用socket的shoudownOutput,后者不推荐使用,后者是直接关闭了输出流,从而导致连接中断,可能会影响后续程序逻辑的执行,而前者是我们手动地去使用标记符来判断,这样的处理更好。

      3、对于资源的关闭,也应该即使去做,这里是Socket、InputStream、OutputStream等资源都需要我们手动地去关闭,防止造成资源泄露,特别是Socket资源,可能会有非常多个客户端要建立连接,但是资源有限,因此会阻塞等待后面的,如果不释放的话,就导致后续客户端无法申请到。

      上述代码虽然能够达到基本的运行效果,但是还存在部分缺陷(TCP的代码):

      1、同一时刻只能有一个客户端去执行服务器的逻辑,因为我们在处理请求时,也是使用的一个循环,因此这里就会导致服务器的逻辑卡在了处理请求的代码中,而不会去尝试建立新的连接。

      解决方法:多线程。将处理请求的代码放到一个新的线程中,这样后续的客户端都只会占用别的线程,而不会占用main线程。

      2、在引入多线程的基础上,又有一个新的问题来了:如果客户端的请求非常简单(回显这种),且同一时刻有非常多的客户端去申请服务器为其服务的话,这时候就会出现线程频繁地创建与删除,这就会导致服务器的性能比较低,因此我们可以创建一个线程池来解决上述问题。

      以上就是使用TCP与UDP实现网络通信的基本过程,后面我们在学习TCP与UDP的通信保障与具体实现等。

      好啦!本期 初始JavaEE篇 —— 网络编程(2):了解套接字,从0到1实现回显服务器 的学习之旅就到此结束啦!我们下一期再一起学习吧!

      版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://blog.csdn.net/2301_80854132/article/details/143592286,作者:我要学编程(ಥ_ಥ),版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

      上一篇:【Redis】Redis数据类型List的安全队列和不安全队列

      下一篇:【Linux】rzsz——本地Windows与云端Linux文件传输工具

      相关文章

      2025-05-19 09:05:01

      项目更新到公网服务器的操作步骤

      项目更新到公网服务器的操作步骤

      2025-05-19 09:05:01
      公网 , 数据库 , 文件 , 更新 , 服务器
      2025-05-19 09:04:44

      FinalShell 配置SSH密钥登陆

      FinalShell 配置SSH密钥登陆

      2025-05-19 09:04:44
      密钥 , 服务器 , 配置
      2025-05-14 10:33:25

      30天拿下Rust之网络编程

      在现代软件开发中,网络编程无处不在。无论是构建高性能的服务器、实时通信应用,还是实现复杂的分布式系统,对网络编程技术的掌握都至关重要。Rust语言以其卓越的安全性、高性能和优秀的并发模型,为网络编程提供了坚实的基础。

      2025-05-14 10:33:25
      Rust , TCP , 使用 , 客户端 , 异步 , 编程
      2025-05-14 10:33:16

      30天拿下Python之使用网络

      Python网络编程覆盖的范围非常广,包括:套接字编程、socketserver、HTTP和Web开发、异步编程和asyncio等。

      2025-05-14 10:33:16
      Json , TCP , 客户端 , 接字 , 服务器 , 示例 , 连接
      2025-05-14 09:51:21

      python 在创建socket之后建立心跳机制

      在Python中,建立心跳机制通常用于维持客户端和服务器之间的长连接,确保连接活跃性。心跳机制通常是通过定时发送心跳包(一种小型的、特定格式的数据包)来实现的,如果在预定时间内没有收到对方的心跳响应,则认为连接可能已经中断。

      2025-05-14 09:51:21
      发送 , 客户端 , 服务器 , 服务器端 , 示例
      2025-05-14 09:51:21

      python向IP地址发送字符串

      在Python中,向IP地址发送字符串通常意味着你需要通过某种协议来实现通信。最常见的协议包括TCP和UDP。这里,我将分别给出使用TCP和UDP协议向指定IP地址发送字符串的示例代码。

      2025-05-14 09:51:21
      TCP , UDP , 协议 , 地址 , 示例 , 端口
      2025-05-13 09:53:23

      在Java、Java Web中放置图片、视频、音频、图像文件的方法

      在Java软件中放置图片,通常涉及将图片文件(如JPEG、PNG等)作为资源包含在我们的项目中,并在代码中通过适当的方式引用这些资源。这可以通过多种方式实现,但最常见的是在Java桌面应用(如Swing或JavaFX)或Web应用(如Servlet/JSP)中。

      2025-05-13 09:53:23
      JSP , URL , Web , 图片 , 服务器
      2025-05-13 09:50:59

      DG搭建过程中备库执行活动复制时报错RMAN-01007、RMAN-01009

      DG搭建过程中备库执行活动复制时报错RMAN-01007、RMAN-01009

      2025-05-13 09:50:59
      RMAN , 客户端 , 语句
      2025-05-09 09:30:19

      Socket类的用法

      Socket类的用法

      2025-05-09 09:30:19
      IP , Socket , 客户端 , 服务端 , 端口
      2025-05-09 09:21:53

      WebAPI 和 webservice的区别

      WebAPI 和 webservice的区别

      2025-05-09 09:21:53
      HTTP , 协议 , 客户端 , 服务器 , 请求
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5229189

      查看更多

      最新文章

      30天拿下Rust之网络编程

      2025-05-14 10:33:25

      30天拿下Python之使用网络

      2025-05-14 10:33:16

      python 在创建socket之后建立心跳机制

      2025-05-14 09:51:21

      DG搭建过程中备库执行活动复制时报错RMAN-01007、RMAN-01009

      2025-05-13 09:50:59

      Socket类的用法

      2025-05-09 09:30:19

      WebAPI 和 webservice的区别

      2025-05-09 09:21:53

      查看更多

      热门文章

      redis-启动服务端-客户端连接服务端

      2023-03-29 10:07:17

      统计客户端连接数

      2023-05-08 10:00:08

      解决rocketmq客户端日志比较大的问题

      2023-03-24 10:33:05

      C/S、B/S、Web的介绍(Web应用开发)

      2023-02-15 08:39:48

      PHP: ThinkPHP获取客户端IP地址

      2023-02-20 10:15:01

      Python套接字Socket服务器-客户端通信编程模型

      2023-04-13 09:36:44

      查看更多

      热门标签

      客户端 实践 基础知识 Java 服务器 java 数据库 框架 python 服务端 学习 代码 简单 javascript 编程
      查看更多

      相关产品

      弹性云主机

      随时自助获取、弹性伸缩的云服务器资源

      天翼云电脑(公众版)

      便捷、安全、高效的云电脑服务

      对象存储

      高品质、低成本的云上存储服务

      云硬盘

      为云上计算资源提供持久性块存储

      查看更多

      随机文章

      Linux之xinetd安装及实践

      《ZooKeeper官方指南》一致性保障

      【网络编程】msgpack

      C语言的网络编程

      windows系统环境c++(c) socket编程实例代码(含服务端和客户端)

      软件设计模式系列之十二——外观模式

      • 7*24小时售后
      • 无忧退款
      • 免费备案
      • 专家服务
      售前咨询热线
      400-810-9889转1
      关注天翼云
      • 旗舰店
      • 天翼云APP
      • 天翼云微信公众号
      服务与支持
      • 备案中心
      • 售前咨询
      • 智能客服
      • 自助服务
      • 工单管理
      • 客户公告
      • 涉诈举报
      账户管理
      • 管理中心
      • 订单管理
      • 余额管理
      • 发票管理
      • 充值汇款
      • 续费管理
      快速入口
      • 天翼云旗舰店
      • 文档中心
      • 最新活动
      • 免费试用
      • 信任中心
      • 天翼云学堂
      云网生态
      • 甄选商城
      • 渠道合作
      • 云市场合作
      了解天翼云
      • 关于天翼云
      • 天翼云APP
      • 服务案例
      • 新闻资讯
      • 联系我们
      热门产品
      • 云电脑
      • 弹性云主机
      • 云电脑政企版
      • 天翼云手机
      • 云数据库
      • 对象存储
      • 云硬盘
      • Web应用防火墙
      • 服务器安全卫士
      • CDN加速
      热门推荐
      • 云服务备份
      • 边缘安全加速平台
      • 全站加速
      • 安全加速
      • 云服务器
      • 云主机
      • 智能边缘云
      • 应用编排服务
      • 微服务引擎
      • 共享流量包
      更多推荐
      • web应用防火墙
      • 密钥管理
      • 等保咨询
      • 安全专区
      • 应用运维管理
      • 云日志服务
      • 文档数据库服务
      • 云搜索服务
      • 数据湖探索
      • 数据仓库服务
      友情链接
      • 中国电信集团
      • 189邮箱
      • 天翼企业云盘
      • 天翼云盘
      ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
      公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
      • 用户协议
      • 隐私政策
      • 个人信息保护
      • 法律声明
      备案 京公网安备11010802043424号 京ICP备 2021034386号