热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

java中TCP/UDP详细总结

本篇文章对Java中的TCPUDP知识点进行了归纳总结分析。需要的朋友参考下

TCP/UDP:TCP主要是面向连接的协议,它包含有建立和拆除连接,保证数据流的顺序和正确性等功能。

每次对TCP中间的数据操作相当于对一个数据流进行访问。它最典型的特征就是那三次握手的建立连接过程。Server端所要做的事情主要是建立一个通信的端点,然后等待客户端发送的请求。典型的处理步骤如下:

1. 构建一个ServerSocket实例,指定本地的端口。这个socket就是用来监听指定端口的连接请求的。

2.重复如下几个步骤:

a. 调用socket的accept()方法来获得下面客户端的连接请求。通过accept()方法返回的socket实例,建立了一个和客户端的新连接。

b.通过这个返回的socket实例获取InputStream和OutputStream,可以通过这两个stream来分别读和写数据。

c.结束的时候调用socket实例的close()方法关闭socket连接。

TCP服务器端:

public class TCPServer {
  public static void main(String[] args){
      try{
        ServerSocket server=new ServerSocket();
        SocketAddress address=new InetSocketAddress(InetAddress.getLocalHost(),10001);
        server.bind(address);
        System.out.println("等待连接客户端...");
        Socket client = server.accept();
        System.out.println("connected with"+client.getRemoteSocketAddress());
        PrintWriter socketOut = new PrintWriter(client.getOutputStream());
        System.out.println("等待客户端的消息...");
        byte buf[] = new byte[1024];
        if ( client.getInputStream().read(buf) > 0 ) {
          System.out.println("收到的消息: " + new String(buf));
        }
        System.out.println("发送消息给客户端...");
        String sendStr = "服务器返回的信息";
        socketOut.write(sendStr);
        socketOut.flush();
        socketOut.close();
        client.close();
        server.close();
      }catch (IOException e) {
        System.out.println(e.getMessage());
        e.printStackTrace();
      }
  }
}

TCP客户端:

1.构建Socket实例,通过指定的远程服务器地址和端口来建立连接。

2.通过Socket实例包含的InputStream和OutputStream来进行数据的读写。

3.操作结束后调用socket实例的close方法,关闭。

public class TCPClient {
  public static void main(String[] args){
    try{
      final Socket socket = new Socket();
      SocketAddress address = new InetSocketAddress(InetAddress.getLocalHost(), 10001);
      System.out.println("连接服务端 ...");
      socket.connect(address);
      PrintWriter socketOut = new PrintWriter(socket.getOutputStream());
      BufferedReader socketIn = new BufferedReader(
          new InputStreamReader(socket.getInputStream()) );
      String sendStr = "客户端发送的消息";
      System.out.println("发送消息给服务端 ...");
      socketOut.write(sendStr);
      socketOut.flush();
      System.out.println("等待服务端的消息 ...");
      String receiveStr = socketIn.readLine();
      System.out.println("收到的消息: " + receiveStr);      
      socketOut.close();
      socketIn.close();
      socket.close();
    }catch (IOException e) {
      System.out.println(e.getMessage());
      e.printStackTrace();
    }
  }
}

UDP(User Datagram Protocol,用户数据报协议)

UDP和TCP有两个典型的区别,一个就是它不需要建立连接,另外就是它在每次收发的报文都保留了消息的边界。

因为UDP协议不需要建立连接,它的过程如下:

1. 构造DatagramSocket实例,指定本地端口。

2. 通过DatagramSocket实例的receive方法接收DatagramPacket.DatagramPacket中间就包含了通信的内容。

3. 通过DatagramSocket的send和receive方法来收和发DatagramPacket.

public class UDPServer {
  public static void main(String args[]) {
    DatagramSocket socket = null;
    DatagramPacket datapacket = null;
    InetSocketAddress address = null;
    try {
      address = new InetSocketAddress(InetAddress.getLocalHost(), 7778);
      socket = new DatagramSocket(address);
      // socket.bind(address);
      byte buf[] = new byte[1024];
      datapacket = new DatagramPacket(buf, buf.length);
      System.out.println("block for receive messages...");
      socket.receive(datapacket);
      buf = datapacket.getData();
      InetAddress addr = datapacket.getAddress();
      int port = datapacket.getPort();
      System.out.println("Message Content: " + new String(buf) );
      System.out.println("Receive From " + addr + ":" + port);      
      SocketAddress toAddress = datapacket.getSocketAddress();
      String sendStr = "I'm Server, this is the message for client.";
      buf = sendStr.getBytes();
      datapacket = new DatagramPacket(buf, buf.length);
      datapacket.setSocketAddress(toAddress);
      socket.send(datapacket);
      System.out.println("message sended");
     //释放资源 
      socket.close(); 
    } catch (UnknownHostException e) {
      e.printStackTrace();
    } catch (SocketException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
}

UDP客户端的步骤也比较简单,主要包括下面3步:

1. 构造DatagramSocket实例。

2.通过DatagramSocket实例的send和receive方法发送DatagramPacket报文。

3.结束后,调用DatagramSocket的close方法关闭。

因为和TCP不同,UDP发送报文的时候可以在同一个本地端口随意发送给不同的服务器,一般不需要在UDP的DatagramSocket的构造函数中指定目的服务器的地址。

另外,UDP客户端还有一个重要的不同就是,TCP客户端发送echo连接消息之后会在调用read方法的时候进入阻塞状态,而UDP这样却不行。因为UDP中间是可以允许报文丢失的。如果报文丢失了,进程一直在阻塞或者挂起的状态,则进程会永远没法往下走了。

所以会一般设置一个setSoTimeout方法,指定在多久的时间内没有收到报文就放弃。也可以通过指定一个数字,循环指定的次数来读取报文,读到就返回,否则就放弃。

public class UDPClient {
  public static void main(String args[]) {
    try {
      DatagramSocket getSocket = new DatagramSocket();
      DatagramPacket datapacket = null;
      InetSocketAddress toAddress = new InetSocketAddress(InetAddress.getLocalHost(), 7778);   
      String sendStr = "I'm client, this is the message for server.";
      byte buf[] = sendStr.getBytes();
      datapacket = new DatagramPacket(buf, buf.length);
      datapacket.setSocketAddress(toAddress);
      getSocket.send(datapacket);
      System.out.println("message sended");
      System.out.println("block for receive messages...");
      getSocket.receive(datapacket);
      buf = datapacket.getData();
      System.out.println("Message Content: " + new String(buf));
      getSocket.close(); 
    } catch (SocketException e) {
      e.printStackTrace();
    } catch (UnknownHostException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
}

以上内容,需要的朋友可以参考


推荐阅读
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细介绍如何使用Samba软件配置CIFS文件共享服务,涵盖安装、配置、权限管理及多用户挂载等关键步骤。通过具体示例和命令行操作,帮助读者快速搭建并优化Samba服务器。 ... [详细]
  • 随着网络安全威胁的不断演变,电子邮件系统成为攻击者频繁利用的目标。本文详细探讨了电子邮件系统中的常见漏洞及其潜在风险,并提供了专业的防护建议。 ... [详细]
  • 本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ... [详细]
  • NTP服务器配置详解:原理与工作模式
    本文深入探讨了网络时间协议(NTP)的工作原理及其多种工作模式,旨在帮助读者全面理解NTP的配置参数和应用场景。NTP是基于RFC 1305的时间同步标准,广泛应用于分布式系统中,确保设备间时钟的一致性。 ... [详细]
  • 访问一个网页的全过程
    准备:DHCPUDPIP和以太网启动主机,用一根以太网电缆连接到学校的以太网交换机,交换机又与学校的路由器相连.学校的这台路由器与一个ISP链接,此ISP(Intern ... [详细]
  • 本文深入探讨了MAC地址与IP地址绑定策略在网络安全中的应用及其潜在风险,同时提供了针对该策略的破解方法和相应的防御措施。 ... [详细]
  • NFS(Network File System)即网络文件系统,是一种分布式文件系统协议,主要用于Unix和类Unix系统之间的文件共享。本文详细介绍NFS的配置文件/etc/exports和相关服务配置,帮助读者理解如何在Linux环境中配置NFS客户端。 ... [详细]
  • 三菱PLC SLMP协议报文详解
    本文详细解析了三菱PLC中使用的SLMP协议报文结构,包括其工作原理、通信流程及报文格式,旨在帮助工程师和技术人员更好地理解和运用这一协议。 ... [详细]
  • 使用C# .NET构建UDP点对点聊天应用
    本文详细介绍如何利用C# .NET框架开发一个基于UDP协议的点对点聊天程序,包括客户端与服务器之间的连接建立、数据传输等核心功能。 ... [详细]
  • 本文将详细探讨 Linux 系统中的 netstat 命令,该命令用于查看网络状态和连接情况。通过了解 IP 地址和端口的基本概念,我们将更好地理解如何利用 netstat 命令来监控和管理网络服务。 ... [详细]
  • TCP/IP基础知识详解
    本文详细介绍了TCP/IP协议的基本概念,包括网络层次模型、TCP三次握手过程、四次挥手过程以及TCP与UDP的比较。通过这些内容,读者可以更好地理解TCP/IP协议的工作原理。 ... [详细]
  • 解析EasyCVR平台国标GB28181协议下的TCP与UDP模式
    在使用EasyCVR视频融合平台过程中,用户常遇到关于端口设置的问题,尤其是TCP和UDP模式的区别。本文将详细介绍这两种模式在GB28181协议下的具体应用及差异。 ... [详细]
  • 一面问题:MySQLRedisKafka线程算法mysql知道哪些存储引擎,它们的区别mysql索引在什么情况下会失效mysql在项目中的优化场景&# ... [详细]
author-avatar
手机用户2602916235
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有