TCP协议

简介: TCP协议

Transmission Control Protocol (TCP) 是一种面向连接的、可靠的传输层协议。它是在计算机网络中用于可靠传输数据的一种重要协议。TCP通过将数据分割成合适的数据块,并在发送和接收端之间建立可靠的连接,实现了高效的数据传输。

TCP的主要特点包括:

  1. 面向连接:在进行数据传输之前,发送端和接收端需要先建立一个TCP连接。连接的建立涉及三次握手,即发送方发送连接请求,接收方回复确认,最后发送方再次回复确认。连接建立后,双方可以进行数据的传输。
  2. 可靠性:TCP使用序列号和确认机制来保证数据的可靠性。发送端将数据分割成适当大小的数据块,并为每个数据块分配一个序列号。接收端收到数据后,会返回一个确认序列号,以告知发送端数据已成功接收。如果发送端在指定时间内未收到确认消息,将会重新发送该数据块。
  3. 流量控制:TCP使用滑动窗口机制来进行流量控制,确保发送端不会压倒接收端。接收端可以根据其处理能力和缓冲区状态来通知发送端所期望的数据量。
  4. 拥塞控制:TCP通过拥塞窗口和拥塞避免算法来控制拥塞的发生。发送端和接收端会根据网络状况和拥塞情况动态调整传输速率,以避免网络拥塞和数据丢失。
  5. 有序性:TCP保证数据在传输过程中的有序性,即接收端按照发送端发送的顺序正确地重构数据。
  6. 差错检测:TCP使用校验和技术,对数据进行差错检测,以确保数据在传输过程中没有被修改或损坏。

TCP广泛应用于互联网和局域网中,例如网页浏览、文件传输、电子邮件、远程登录等各种网络应用。由于TCP提供了可靠性和有序性的传输,能够适应不同网络环境的要求,因此成为了互联网中最常用的传输协议之一。

java实现TCP协议代码如下:

客户端:

import java.io.*;
import java.net.*;
public class TCPClient {
    public static void main(String[] args) {
        String serverHost = "127.0.0.1"; // 服务器 IP 地址
        int serverPort = 12345; // 服务器端口号
        try {
            // 建立与服务器的连接
            Socket socket = new Socket(serverHost, serverPort);
            // 获取输入流和输出流
            OutputStream outputStream = socket.getOutputStream();
            InputStream inputStream = socket.getInputStream();
            // 发送数据到服务器
            String message = "Hello, Server!";
            outputStream.write(message.getBytes());
            // 接收服务器返回的数据
            byte[] buffer = new byte[1024];
            int length = inputStream.read(buffer);
            String response = new String(buffer, 0, length);
            System.out.println("Server response: " + response);
            // 关闭连接
            socket.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
  1. 首先定义了服务器的 IP 地址和端口号。
  2. 在 try-catch 块中,通过创建 Socket 对象来建立与服务器的连接:Socket socket = new Socket(serverHost, serverPort);。这里使用指定的服务器 IP 地址和端口号创建了一个 Socket 对象。
  3. 获取输入流和输出流:OutputStream outputStream = socket.getOutputStream();InputStream inputStream = socket.getInputStream();。使用 Socket 对象的 getOutputStream() 方法获取输出流,用于向服务器发送数据;使用 getInputStream() 方法获取输入流,用于接收从服务器返回的数据。
  4. 向服务器发送数据:outputStream.write(message.getBytes());。这里将字符串 "Hello, Server!" 转换为字节数组,并通过输出流将数据发送给服务器。
  5. 接收服务器返回的数据:inputStream.read(buffer);。使用输入流的 read() 方法从服务器读取数据,并将读取的内容存储在缓冲区 buffer 中。
  6. 将服务器响应打印到控制台:String response = new String(buffer, 0, length);System.out.println("Server response: " + response);。将从服务器接收到的字节数组转换为字符串,并将其打印到控制台。
  7. 最后关闭连接:socket.close();。关闭 Socket 连接。

服务器代码:

import java.io.*;
import java.net.*;
public class TCPServer {
    public static void main(String[] args) {
        int serverPort = 12345; // 服务器监听的端口号
        try {
            // 创建服务器套接字并绑定到指定的端口
            ServerSocket serverSocket = new ServerSocket(serverPort);
            System.out.println("Server listening on port " + serverPort);
            // 接受客户端的连接
            Socket socket = serverSocket.accept();
            // 获取输入流和输出流
            InputStream inputStream = socket.getInputStream();
            OutputStream outputStream = socket.getOutputStream();
            // 接收客户端发送的数据
            byte[] buffer = new byte[1024];
            int length = inputStream.read(buffer);
            String request = new String(buffer, 0, length);
            System.out.println("Received from client: " + request);
            // 向客户端发送响应数据
            String response = "Hello, Client!";
            outputStream.write(response.getBytes());
            // 关闭连接
            socket.close();
            serverSocket.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

 

  1. 首先定义了服务器监听的端口号。
  2. 在 try-catch 块中,通过创建 ServerSocket 对象来监听指定端口:ServerSocket serverSocket = new ServerSocket(serverPort);。这里使用指定的端口号创建了一个 ServerSocket 对象,用于监听来自客户端的连接请求。
  3. 打印服务器监听端口号:System.out.println("Server listening on port " + serverPort);。将服务器监听的端口号打印到控制台。
  4. 接受客户端的连接:Socket socket = serverSocket.accept();。通过调用 accept() 方法,服务器等待并接受来自客户端的连接请求,并返回一个 Socket 对象用于之后的数据传输。
  5. 获取输入流和输出流:InputStream inputStream = socket.getInputStream();OutputStream outputStream = socket.getOutputStream();。使用 Socket 对象的 getInputStream() 方法获取输入流,用于接收客户端发送的数据;使用 getOutputStream() 方法获取输出流,用于向客户端发送数据。
  6. 接收客户端发送的数据:inputStream.read(buffer);。通过输入流的 read() 方法从客户端读取数据,并将读取的内容存储在缓冲区 buffer 中。
  7. 将客户端请求打印到控制台:String request = new String(buffer, 0, length);System.out.println("Received from client: " + request);。将从客户端接收到的字节数组转换为字符串,并将其打印到控制台。
  8. 向客户端发送响应数据:outputStream.write(response.getBytes());。这里将字符串 "Hello, Client!" 转换为字节数组,并通过输出流将响应数据发送给客户端。
  9. 最后关闭连接:socket.close();serverSocket.close();。先关闭 Socket 连接,再关闭 ServerSocket 服务器套接字。


相关文章
|
Kubernetes 安全 网络协议
【K8S系列】深入解析k8s网络插件—Calico
【K8S系列】深入解析k8s网络插件—Calico
5129 0
|
前端开发 Go API
Day08:GORM快速入门07 has many| 青训营
Day08:GORM快速入门07 has many| 青训营
|
前端开发 中间件 Java
Day05:Gin框架快速入门05 中间件和路由 | 青训营
Day05:Gin框架快速入门05 中间件和路由 | 青训营
|
存储 前端开发 程序员
Day05:Gin框架快速入门04 文件上传和下载| 青训营
Day05:Gin框架快速入门04 文件上传和下载| 青训营
|
前端开发 Go API
Day07:GORM快速入门04 查找| 青训营
Day07:GORM快速入门04 查找| 青训营
|
存储 Java Go
Day01:Go语言基础语法速过 | 青训营
Day01:Go语言基础语法速过 | 青训营
|
存储 前端开发 Go
Day08:GORM快速入门06 HasOne| 青训营
Day08:GORM快速入门06 HasOne| 青训营
|
前端开发 Go API
Day08:GORM快速入门08 many to many| 青训营
Day08:GORM快速入门08 many to many| 青训营
|
前端开发 Go API
Day08:GORM快速入门06 属于| 青训营
Day08:GORM快速入门06 属于| 青训营
|
存储 前端开发 数据库连接
Day07:GORM快速入门05 更新| 青训营
Day07:GORM快速入门05 更新| 青训营

热门文章

最新文章