TCP协议简单总结

TCP:传输控制协议

  • 特点:面向连接、可靠通信

  • TCP的最终目的:要保证在不可靠的信道上实现可靠的传输

  • TCP主要有三个步骤实现可靠传输:三次握手建立连接,传输数据进行确认,四次挥手断开连接

    • 三次握手建立可靠连接。

    • 建立连接后会建立可靠的通信管道

    • 四次握手断开连接

TCP通信之客户端开发

客户端发送信息:

java 复制代码
import java.io.*;
import java.net.*;

public class TCPClient {
    public static void main(String[] args) {
        final String serverAddress = "127.0.0.1"; // 服务器地址
        final int serverPort = 8080; // 服务器端口

        try {
            // 连接到服务器
            Socket socket = new Socket(serverAddress, serverPort);
            System.out.println("Connected to server.");

            // 发送消息到服务器
            sendMessage(socket, "Hello, Server!");

            // 接收服务器的响应
            String response = receiveMessage(socket);
            System.out.println("Response from server: " + response);

            // 关闭连接
            socket.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    private static void sendMessage(Socket socket, String message) throws IOException {
        PrintWriter out = new PrintWriter(socket.getOutputStream(), true);
        out.println(message);
    }

    private static String receiveMessage(Socket socket) throws IOException {
        BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
        return in.readLine();
    }
}

TCP通信之服务端开发

服务端接收信息

java 复制代码
import java.io.*;
import java.net.*;

public class TCPExample {
    public static void main(String[] args) {
        final int PORT = 8080;

        try {
            // 启动服务器
            ServerSocket serverSocket = new ServerSocket(PORT);
            System.out.println("Server started. Waiting for connections...");

            // 等待客户端连接
            Socket clientSocket = serverSocket.accept();
            System.out.println("Client connected: " + clientSocket);

            // 处理客户端请求
            handleClient(clientSocket);

            // 关闭服务器
            serverSocket.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    public static void handleClient(Socket clientSocket) {
        try {
            // 接收客户端消息
            BufferedReader in = new BufferedReader(new InputStreamReader(clientSocket.getInputStream()));
            String message = in.readLine();
            System.out.println("Received message from client: " + message);

            // 向客户端发送响应
            PrintWriter out = new PrintWriter(clientSocket.getOutputStream(), true);
            out.println("Hello, Client!");

            // 关闭连接
            clientSocket.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
相关推荐
ZePingPingZe15 小时前
不使用Spring事务的管理—原生JDBC实现事务管理
java·数据库·spring
网安INF15 小时前
电子邮件的系统架构和核心协议详解
网络·网络协议·安全·网络安全·密码学·电子邮件
络合白泽15 小时前
【效率提升】告别繁琐密码与难记 IP:如何优雅地使用 SSH 进行开发部署
网络协议·tcp/ip·ssh
吃喝不愁霸王餐APP开发者15 小时前
外卖API对接过程中时间戳与时区处理的最佳实践(避免核销失效)
java
老蒋新思维15 小时前
创客匠人分享:从“个人品牌”到“智能系统”,创始人IP如何穿越变现周期?
网络·人工智能·网络协议·tcp/ip·重构·创始人ip·创客匠人
抹除不掉的轻狂丶15 小时前
Java 日志框架完整指南:发展历史、核心组成与最佳实践
java·开发语言·python
林涧泣15 小时前
使用Java输出HelloWorld
java·开发语言
元亓亓亓15 小时前
考研408--计算机网络--day11--TCP的可靠传输、流量控制及拥塞控制
网络·tcp/ip·计算机网络
写代码的橘子n15 小时前
IPV6复习(基础入手版)
运维·服务器·网络
APIshop16 小时前
高性能采集方案:淘宝商品 API 的并发调用与数据实时处理
linux·网络·算法