TCP套接字通信核心要点

TCP套接字通信核心要点


通信模型架构

客户端-服务端模型

  • CS架构:客户端发起请求,服务端响应和处理请求
  • 双向通道:建立连接后实现全双工通信

服务端搭建流程

核心步骤

  1. 创建套接字

    复制代码
    int server = socket(AF_INET, SOCK_STREAM, 0);
    • 参数说明:AF_INET(IPv4)、SOCK_STREAM(TCP)、协议自动选择
  2. 绑定地址

    复制代码
    struct sockaddr_in addr = {
        .sin_family = AF_INET,
        .sin_port = htons(port),
        .sin_addr.s_addr = INADDR_ANY
    };
    bind(server, (struct sockaddr*)&addr, sizeof(addr));
    • 关键操作:字节序转换(htons)、IP绑定策略(INADDR_ANY
  3. 监听连接

    复制代码
    listen(server, 10); // 监听队列长度=10
  4. 接受连接

    复制代码
    int client = accept(server, (struct sockaddr*)&client_addr, &client_len);
    • 获取客户端地址:inet_ntop转换IP,ntohs转换端口
  5. 数据交互

    • 读取数据:read()recv()
    • 终止条件:返回值为0时表示客户端断开

客户端搭建流程

核心步骤

  1. 创建套接字

    复制代码
    int client = socket(AF_INET, SOCK_STREAM, 0);
  2. 设置服务端地址

    复制代码
    struct sockaddr_in addr = {
        .sin_family = AF_INET,
        .sin_port = htons(server_port),
        .sin_addr.s_addr = inet_addr("192.168.1.1")
    };
  3. 建立连接

    复制代码
    connect(client, (struct sockaddr*)&addr, sizeof(addr));
  4. 发送数据

    复制代码
    write(client, buffer, sizeof(buffer));

协议包设计

结构体定义

复制代码
typedef struct Pack {
    int packsize;    // 总字节数(含包头)
    char buf[4096];  // 数据缓冲区
    int used;        // 已使用字节数
} pack_t;

关键操作

  1. 数据封装

    复制代码
    void append(pack_t* pack, const char* str) {
        short len = strlen(str);
        *(short*)(pack->buf + pack->used) = len; // 写入长度
        memcpy(pack->buf + pack->used + 2, str, len); // 写入内容
        pack->used += (len + 2);
        pack->packsize = 4 + pack->used; // 更新总大小(含4字节包头)
    }
  2. 数据解析

    复制代码
    char** analysis(pack_t* pack) {
        char* buf = pack->buf;
        char** list = calloc(20, 8); // 存储解析后的字段
        int readed_size = 0;
        while (*(short*)(buf + readed_size) != 0) {
            short len = *(short*)(buf + readed_size);
            readed_size += 2;
            memcpy(temp, buf + readed_size, len);
            list[i++] = strdup(temp); // 动态分配存储
        }
        return list;
    }

关键问题处理

粘包与拆包

  • 粘包:多次发送的小数据包合并传输
  • 拆包:大数据包拆分发送(如超过1500字节限制)
  • 解决方案:协议包头声明数据长度,接收方按长度解析

连接管理

  • 服务端维护 :通过accept()返回的客户端描述符管理多个连接
  • 异常断开检测read()返回0时表示客户端主动关闭

代码实践要点

  • 错误处理 :检查socket()/bind()/listen()/connect()的返回值
  • 资源释放close()关闭套接字,free()释放动态内存
  • 字节序转换 :端口号使用htons/ntohs,IP使用inet_ntop/pton

总结:TCP套接字通信围绕地址绑定、连接管理、协议设计展开,需掌握服务端/客户端搭建流程、粘包处理及协议包解析方法,结合错误处理实现稳定通信。

相关推荐
24zhgjx-lxq13 分钟前
华为ensp:MSTP
网络·安全·华为·hcip·ensp
ling___xi15 分钟前
《计算机网络》计网3小时期末速成课各版本教程都可用谢稀仁湖科大版都可用_哔哩哔哩_bilibili(笔记)
网络·笔记·计算机网络
REDcker26 分钟前
Linux 文件描述符与 Socket 选项操作详解
linux·运维·网络
Up九五小庞1 小时前
用arpspoof实现100%批量切断192.168.110.10 - 192.168.110.100 断网(双向欺骗)--九五小庞
网络·开源
躺柒1 小时前
读数字时代的网络风险管理:策略、计划与执行04风险指引体系
大数据·网络·信息安全·数字化·网络管理·网络风险管理
AndyHeee1 小时前
【windows使用TensorFlow,GPU无法识别问题汇总,含TensorFlow完整安装过程】
人工智能·windows·tensorflow
远程修电脑→24169767751 小时前
三角洲行动弹窗提示CPU虚拟化未开启或被占用启动腾讯游戏时出现【ACE安全中心】虚拟化相关报错
windows
188_djh1 小时前
# 15_电脑版百度网盘每次登录都显示安全验证,很麻烦,一招解决
windows·app·百度网盘·百度网盘安全验证·baidudisk
独角鲸网络安全实验室1 小时前
本地信任成“致命漏洞”:数千Clawdbot Agent公网裸奔,供应链与内网安全告急
网络·网关·安全·php·漏洞·clawdbot·信任机制漏洞
郭涤生1 小时前
C++的函数是否可以做到完全覆盖Linux和windows的跨平台
linux·c++·windows