当前位置: 首页 > news >正文

网络编程基础:从 OSI 模型到 TCP/IP 协议族的全面解析

网络编程是现代软件开发中不可或缺的一部分,它涉及到计算机之间的数据交换和通信。本文将从基础理论入手,详细解析 OSI 模型和 TCP/IP 协议族,然后深入探讨 TCP 编程的基础知识,最后介绍常用的网络测试工具。通过理论与实践相结合的方式,帮助读者全面掌握网络编程的核心概念和技能。

一、网络模型:OSI 与 TCP/IP
1. OSI 模型(开放系统互联模型)

OSI 模型将网络通信分为七层,虽然是理想模型但尚未完全实现:

  • 应用层:为用户提供应用程序服务(如电子邮件、文件传输)。
  • 表示层:处理数据表示和转换(如加密、压缩)。
  • 会话层:管理会话建立、维护和终止(如 keep-alive 机制)。
  • 传输层:提供端到端的可靠(TCP)或不可靠(UDP)传输。
  • 网络层:负责路由选择和 IP 寻址(如 NAT)。
  • 数据链路层:处理物理链路的数据帧传输(如交换机、帧校验)。
  • 物理层:传输比特流(如电缆、无线信号)。
2. TCP/IP 模型(网际互联模型)

TCP/IP 是实用的工业标准,分为四层:

  • 应用层:包含 HTTP、FTP、DNS 等协议。
  • 传输层:TCP 和 UDP 协议。
  • 网络层:IP、ICMP 等协议。
  • 接口层:负责物理连接(如网卡驱动)。
二、TCP/IP 协议族详解

TCP/IP 协议族是互联网的基础,包含众多协议:

  • 应用层:HTTP(网页)、TFTP(简单文件传输)、FTP(文件传输)、SNMP(网络管理)、DNS(域名解析)。
  • 传输层:TCP(可靠连接)和 UDP(无连接)。
  • 网络层:IP(寻址)、ICMP(网络控制)、RIP/OSPF(路由)、IGMP(组播)。
  • 物理层:ARP(IP 到 MAC 地址解析)、RARP(反向解析)。
三、TCP 编程基础知识
1. IP 地址分类

IP 地址分为五类,常见的是 A、B、C 类:

  • A 类:1.0.0.0 - 126.255.255.255(默认掩码:255.0.0.0)。
  • B 类:128.0.0.0 - 191.255.255.255(默认掩码:255.255.0.0)。
  • C 类:192.0.0.0 - 223.255.255.255(默认掩码:255.255.255.0)。
  • 私有地址:10.0.0.0/8、172.16.0.0/12、192.168.0.0/16。
2. 网络接口与套接字(Socket)
  • Socket:网络通信的接口,通过 socket() 函数创建。
  • 地址与端口:IP 地址标识主机,端口(1-65535)标识应用程序。
  • 字节序转换:网络字节序为大端序,使用 htons()htonl() 等函数转换。
3. TCP 编程流程

服务器端

socket() → bind() → listen() → accept() → recv() → close()

客户端

socket() → connect() → send() → close()
四、TCP 编程实战

以下是一个简单的 TCP 服务器和客户端示例:

服务器端代码(01ser.c

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <unistd.h>typedef struct sockaddr *SA;int main(int argc, char **argv) {// 创建套接字int udpfd = socket(AF_INET, SOCK_STREAM, 0);if (udpfd == -1) {perror("socket");return 1;}// 设置服务器地址struct sockaddr_in ser;memset(&ser, 0, sizeof(ser));ser.sin_family = AF_INET;ser.sin_port = htons(50000);ser.sin_addr.s_addr = inet_addr("192.168.31.248");// 绑定地址if (bind(udpfd, (SA)&ser, sizeof(ser)) == -1) {perror("bind");return 1;}// 监听连接if (listen(udpfd, 5) == -1) {perror("listen");return 1;}printf("等待客户端连接...\n");// 接受客户端连接struct sockaddr_in cli;socklen_t len = sizeof(cli);int connfd = accept(udpfd, (SA)&cli, &len);if (connfd == -1) {perror("accept");return 1;}printf("客户端已连接: %s:%d\n", inet_ntoa(cli.sin_addr), ntohs(cli.sin_port));// 接收数据char buf[1024];while (1) {memset(buf, 0, sizeof(buf));ssize_t ret = recv(connfd, buf, sizeof(buf), 0);if (ret <= 0) {printf("客户端断开连接\n");break;}printf("客户端消息: %s\n", buf);}// 关闭连接close(connfd);close(udpfd);return 0;
}

客户端代码(02cli.c

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <unistd.h>typedef struct sockaddr *SA;int main(int argc, char **argv) {// 创建套接字int udpfd = socket(AF_INET, SOCK_STREAM, 0);if (udpfd == -1) {perror("socket");return 1;}// 设置服务器地址struct sockaddr_in ser;memset(&ser, 0, sizeof(ser));ser.sin_family = AF_INET;ser.sin_port = htons(50000);ser.sin_addr.s_addr = inet_addr("192.168.31.248");// 连接服务器if (connect(udpfd, (SA)&ser, sizeof(ser)) == -1) {perror("connect");return 1;}printf("已连接到服务器\n");// 发送数据char buf[1024];while (1) {memset(buf, 0, sizeof(buf));printf("输入消息(输入 'exit' 退出): ");fgets(buf, sizeof(buf), stdin);// 去除换行符buf[strcspn(buf, "\n")] = 0;if (strcmp(buf, "exit") == 0) {break;}// 发送数据send(udpfd, buf, strlen(buf), 0);}// 关闭连接close(udpfd);return 0;
}
五、常用网络测试工具
  1. telnet:远程登录工具,用于测试端口连通性。

    telnet 192.168.1.1 8080
    
  2. netstat:查看网络连接和端口状态。

    netstat -anp  # 查看所有连接和进程信息
    
  3. ping:测试网络连通性。

    ping www.baidu.com
    
  4. arp:查看和管理 ARP 缓存。

    arp -an  # 显示 ARP 表
    
  5. 抓包工具

    • Wireshark:图形界面抓包工具。
    • tcpdump:命令行抓包工具。
      tcpdump -n -i eth0 src or dst 192.168.1.100  # 抓指定 IP 的包
      
六、TCP 三次握手与四次挥手
1. 三次握手(建立连接)
  1. 客户端发送 SYN 包到服务器。
  2. 服务器回复 SYN+ACK 包。
  3. 客户端发送 ACK 包完成连接。
2. 四次挥手(关闭连接)
  1. 客户端发送 FIN 包表示请求关闭。
  2. 服务器回复 ACK 确认。
  3. 服务器发送 FIN 包表示请求关闭。
  4. 客户端回复 ACK 确认。
七、总结

网络编程是一个复杂而庞大的领域,本文从 OSI 模型和 TCP/IP 协议族出发,详细介绍了 TCP 编程的基础知识和实践技巧,以及常用的网络测试工具。掌握这些内容是进行网络编程的基础,希望读者通过本文能够建立起完整的网络编程知识体系,并在实践中不断深化理解。

通过后续的练习和作业(如发送结构体数据、文件传输等),读者可以进一步巩固所学知识,逐步成为网络编程的高手。

http://www.lryc.cn/news/594763.html

相关文章:

  • Android 中 SystemServiceManager 和 ServiceManager 的应用场景、区别与联系
  • 漏洞扫描 + 渗透测试:双轮驱动筑牢网络安全防线
  • Ubuntu 22.04 使用 Docker 安装 Redis 5 (安装包形式)
  • 内网与外网是通过什么进行传输的?内外网文件传输的安全方法
  • C#最佳实践:为何应尽量减少静态类的使用
  • 迅为八核高算力RK3576开发板摄像头实时推理测试 RetinaFace人脸检测
  • Curtain e-locker 易锁防泄密:无需网络隔离,实现安全与效率并存
  • 大腾智能国产3D CAD软件正式上架华为云云商店
  • 进程资源分配的安全性判断与安全序列
  • ZooKeeper学习专栏(四):单机模式部署与基础操作详解
  • 【c++】leetcode5 最长回文子串
  • 突破量子仿真瓶颈:微算法科技MLGO量子算法的算术化与核操作迭代模型
  • 飞算科技:以原创技术为翼,赋能产业数字化转型
  • Spring 中的 Bean 作用域(Scope)有哪些?各自适用于什么场景?
  • 江苏思必驰科技25Java实习面经
  • react class和function 如何模拟vue中的 双向绑定 监听 computed的方式
  • Component cannot be used as a JSX component
  • 芯谷科技--固定电压基准双运算放大器D4310
  • 杰和科技工业计算机AF208,打造高可靠新能源汽车检测产线
  • 杰发科技AC7840——硬件crc使用
  • 【烧脑算法】拓扑排序:从“依赖”到“序列”,理解题目中的先后逻辑
  • 5.6 framebuffer驱动
  • 录音转写:颠覆传统共享下载体验 | 如何提升团队效率?
  • 【前端状态更新与异步协调完全指南:React、Vue架构原理与复杂业务场景实战】
  • RustDesk自建服务器完整部署指南:从零开始到成功连接。成功解决rustdesk报错:未就绪,请检查网络连接
  • Vue 脚手架——render函数
  • 网络与信息安全有哪些岗位:(1)网络安全工程师
  • 【系统全面】Linux进程——基础知识介绍
  • 在本地WSL中的CentOS 7子系统中部署Ewomail邮件服务器
  • AC身份认证实验之AAA服务器