20-LINUX--网络编程

news2025/1/10 12:22:33

一. 主机字节序列和网络字节序列

主机字节序列分为大端字节序和小端字节序,不同的主机采用的字节序列可能不同。大
端字节序是指一个整数的高位字节存储在内存的低地址处,低位字节存储在内存的高地址
处。小端字节序则是指整数的高位字节存储在内存的高地址处,而低位字节则存储在内存的
低地址处。在两台使用不同字节序的主机之间传递数据时,可能会出现冲突。所以,在将数
据发送到网络时规定整形数据使用大端字节序,所以也把大端字节序成为网络字节序列。对
方接收到数据后,可以根据自己的字节序进行转换。
Linux 系统提供如下 4 个函数来完成主机字节序和网络字节序之间的转换:
 #include <netinet/in.h>

 uint32_t htonl(uint32_t hostlong); // 长整型的主机字节序转网络字节序
 
 uint32_t ntohl(uint32_t netlong); // 长整型的网络字节序转主机字节序

 uint16_t htons(uint16_t hostshort); // 短整形的主机字节序转网络字节序

 uint16_t ntohs(uint16_t netshort); // 短整型的网络字节序转主机字节序

二.套接字地址结构

1.专用 socket 地址结构

soc
TCP/IP 协议族有 sockaddr_in 和 sockaddr_in6 两个专用 socket 地址结构体,它们分
别用于 IPV4 和 IPV6:

 sin_family: 地址族 AF_INET
 sin_port: 端口号,需要用网络字节序表示
 sin_addr: IPV4 地址结构:s_addr 以网络字节序表示 IPV4 地址
 

2.IP 地址转换函数

人们习惯用点分十进制字符串表示 IPV4 地址,但编程中我们需要先把它们转化 为整数方能使用,下面函数可用于点分十进制字符串表示的 IPV4 地址和网络字节序整数表 示的 IPV4 地址之间的转换:

 #include <arpa/inet.h>
 in_addr_t inet_addr(const char *cp); //字符串表示的 IPV4 地址转化为网络字节序
 char* inet_ntoa(struct in_addr in); // IPV4 地址的网络字节序转化为字符串表示

3.网络编程接口

1. #include <sys/types.h>
2. #include <sys/socket.h>
3.
4. /*************************************************************
5. socket()创建套接字,成功返回套接字的文件描述符,失败返回-1
6. domain: 设置套接字的协议簇, AF_UNIX AF_INET AF_INET6
7. type: 设置套接字的服务类型 SOCK_STREAM SOCK_DGRAM
8. protocol: 一般设置为 0,表示使用默认协议
9. *************************************************************/
10. int socket(int domain, int type, int protocol);
11.
12. /*************************************************************
13. bind()将 sockfd 与一个 socket 地址绑定,成功返回 0,失败返回-1
14. sockfd 是网络套接字描述符
15. addr 是地址结构
16. addrlen 是 socket 地址的长度
17. **************************************************************/
18. int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
19.
20. /*************************************************************
21. listen()创建一个监听队列以存储待处理的客户连接,成功返回 0,失败返回-1
22. sockfd 是被监听的 socket 套接字
23. backlog 表示处于完全连接状态的 socket 的上限
24. **************************************************************/
25. int listen(int sockfd, int backlog);
26.
27. /*************************************************************
28. accept()从 listen 监听队列中接收一个连接,成功返回一个新的连接 socket,
29. 该 socket 唯一地标识了被接收的这个连接,失败返回-1
30. sockfd 是执行过 listen 系统调用的监听 socket
31. addr 参数用来获取被接受连接的远端 socket 地址
32. addrlen 指定该 socket 地址的长度
33. *************************************************************/
34. int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
35.
36. /*************************************************************
37. connect()客户端需要通过此系统调用来主动与服务器建立连接,
134 到图论,学 IT,找好工作
图论科技
38. 成功返回 0,失败返回-1
39. sockfd 参数是由 socket()返回的一个 socket。
40. serv_addr 是服务器监听的 socket 地址
41. addrlen 则指定这个地址的长度
42. *************************************************************/
43. int connect(int sockfd, const struct sockaddr *serv_addr, socklen_t addrlen);
44.
45. /*************************************************************
46. close()关闭一个连接,实际上就是关闭该连接对应的 socket
47. *************************************************************/
48. int close(int sockfd);
49.
50. /**************************************************************
51. TCP 数据读写:
52. recv()读取 sockfd 上的数据,buff 和 len 参数分别指定读缓冲区的位置和大小
53. send()往 socket 上写入数据,buff 和 len 参数分别指定写缓冲区的位置和数据长
度
54. flags 参数为数据收发提供了额外的控制
55. **************************************************************/
56. ssize_t recv(int sockfd, void *buff, size_t len, int flags);
57. ssize_t send(int sockfd, const void *buff, size_t len, int flags);
58.
59. /**************************************************************
60. UDP 数据读写:
61. recvfrom()读取 sockfd 上的数据,buff 和 len 参数分别指定读缓冲区的位置和大
小
62. src_addr 记录发送端的 socket 地址
63. addrlen 指定该地址的长度
64. sendto()往 socket 上写入数据,buff 和 len 参数分别指定写缓冲区的位置和数据长
度
65. dest_addr 指定接收数据端的 socket 地址
66. addrlen 指定该地址的长度
67. **************************************************************/
68. ssize_t recvfrom(int sockfd, void *buff, size_t len, int flags,
69. struct sockaddr* src_addr, socklen_t *addrlen);
70. ssize_t sendto(int sockfd, void *buff, size_t len, int flags,
71. struct sockaddr* dest_addr, socklen_t addrlen);

三.TCP编程流程

        (1). socket()方法是用来创建一个套接字,有了套接字就可以通过网络进行数据的收发。这也是为什么进行网络通信的程序首先要创建一个套接字。创建套接字时要指定使用的服务类 型,使用 TCP 协议选择流式服务(SOCK_STREAM)。
        (2). bind()方法是用来指定套接字使用的 IP 地址和端口。IP 地址就是自己主机的地址,如果主机没有接入网络,测试程序时可以使用回环地址“127.0.0.1”。端口是一个 16 位的整形值,一般 0-1024 为知名端口,如 HTTP 使用的 80 号端口。这类端口一般用户不能随便使用。其次,1024-4096 为保留端口,用户一般也不使用。4096 以上为临时端口,用户可以使用。在Linux 上,1024 以内的端口号,只有 root 用户可以使用。
        (3).  listen()方法是用来创建监听队列。监听队列有两种,一个是存放未完成三次握手的连接,一种是存放已完成三次握手的连接。listen()第二个参数就是指定已完成三次握手队列的长度。
        (4). accept()处理存放在 listen 创建的已完成三次握手的队列中的连接。每处理一个连接,则  accept()返回该连接对应的套接字描述符。如果该队列为空,则 accept 阻塞。
        (5). connect()方法一般由客户端程序执行,需要指定连接的服务器端的 IP 地址和端口。该方法执行后,会进行三次握手, 建立连接。
        (6).send()方法用来向 TCP 连接的对端发送数据。send()执行成功,只能说明将数据成功写入 到发送端的发送缓冲区中,并不能说明数据已经发送到了对端。send()的返回值为实际写入 到发送缓冲区中的数据长度。
        (7).recv()方法用来接收 TCP 连接的对端发送来的数据。recv()从本端的接收缓冲区中读取数据,如果接收缓冲区中没有数据,则 recv()方法会阻塞。返回值是实际读到的字节数,如果
        (8).recv()返回值为 0, 说明对方已经关闭了 TCP 连接。
        (9).close()方法用来关闭 TCP 连接。此时,会进行四次挥手。
CLI.C
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<unistd.h>
#include<sys/socket.h>
#include<arpa/inet.h>
#include<netinet/in.h>

int main()
{
        int sockfd = socket(AF_INET,SOCK_STREAM,0);
        if(sockfd == -1)
        {
                exit(1);
        }

        struct sockaddr_in saddr; //IPV4地址结构 服务器地址 
        memset(&saddr,0,sizeof(saddr));
        saddr.sin_family = AF_INET;
        saddr.sin_port = htons(6000); //服务器端口
        saddr.sin_addr.s_addr = inet_addr("127.0.0.1");
        int n = connect(sockfd,(struct sockaddr*)&saddr,sizeof(saddr));
        if(n == -1)
        {
                printf("connect err\n");
                exit(1);
        }

        char buff[128] = {0};

        fgets(buff,128,stdin);
        send(sockfd,buff,strlen(buff)-1,0);
        memset(buff,0,sizeof(saddr));

        recv(sockfd,buff,127,0);
        printf("buff = %s\n",buff);

        close(sockfd);

        exit(0);

}

SER.C

#include<stdio.h>
#include<string.h>
#include<unistd.h>
#include<stdlib.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<arpa/inet.h>


int main()
{
        int sockfd = socket(AF_INET,SOCK_STREAM,0);//创建套接子//tcp SOCK_STREAM
        //套接子通过网络收发数据
        if(sockfd == -1)
        {
                exit(1);
        }

        struct sockaddr_in saddr,caddr;
        memset(&saddr,0,sizeof(saddr));
        saddr.sin_family = AF_INET;//填写地址族
        saddr.sin_port = htons(6000);//端口
        saddr.sin_addr.s_addr=inet_addr("127.0.0.1");//IP

        int res = bind(sockfd,(struct sockaddr*)&saddr,sizeof(saddr));//绑定
        if(res ==-1)
        {
                printf("bind err\n");
                exit(1);
        }
        //创建监听队列
        listen(sockfd,5);

        while(1)
        {
                int len = sizeof(caddr);
                int c = accept(sockfd,(struct sockaddr*)&caddr,&len);
                if(c <0)
                {
                        continue;
                }
                printf("accept c=%d\n",c);
                //接收客户端发来的数据
                char buff[128] = {0};
                int n = recv(c, buff,127,0);
                printf("buff = %s\n",buff);
                //恢复数据
                send(c,"ok",2,0);
                close(c);
        }

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1669690.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Linux系统编程】第十七弹---进程理解

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】 目录 1、进程的基本概念 2、描述进程-PCB 2.1、什么是PCB 2.2、为什么要有PCB 3、task_ struct 3.1、启动进程 3.2、创建进程…

Qt之QMqtt 发送图片数据

简述 MQTT(消息队列遥测传输)是ISO标准下基于发布/订阅范式的消息协议;它工作在TCP/IP协议族上,是为硬件性能低下的远程设备以及网络状况糟糕的情况下而设计的发布/订阅型消息协议,为此,它需要一个消息中间件; MQTT是一个基于客户端-服务器的消息发布/订阅传输协议;MQT…

Spring Security 复盘

1、什么Spring Security&#xff1f; Spring Security 是一种强大的框架&#xff0c;它在 Spring 生态系统中扮演着保护应用安全的关键角色。Spring Security 基于 Spring 框架&#xff0c;提供了一套 Web 应用安全性的完整解决方案。 2、认证 和 授权 1.什么是认证&#xff1…

电子合同怎么加盖电子章?

加盖电子章在电子合同上的过程通常涉及以下几个步骤&#xff0c;这里提供一个较为通用的流程&#xff0c;但请注意&#xff0c;具体操作可能会因不同的电子签名平台或软件而有所差异&#xff1a; 准备电子合同&#xff1a; 将合同内容编辑完成后&#xff0c;通常会保存为PDF格式…

解锁得物搬砖秘籍:实现稳定收益的秘诀大公开

01、项目介绍 目前比较常用的平台是淘宝&#xff0c;京东&#xff0c;拼多多&#xff0c;唯品会这些为主&#xff0c;以各品牌APP&#xff0c;小程序为辅。 从这些电商平台通过抢购&#xff0c;折扣等方式购买到相对低价的鞋子衣服等&#xff0c;货到手检查没有问题后&#x…

python绘制圣诞树 如何用python绘制一个圣诞树

欢迎关注我👆,收藏下次不迷路┗|`O′|┛ 嗷~~ 目录 一.前言 二.代码 三.使用 四.总结 一.前言 圣诞树,是指用灯烛和装饰品把枞树或洋松装点起来的常青树。作为是圣诞节重要的组成元素之一,近代圣诞树起源于德国,后来逐步在世界范围内流行起来

掌握 Spring Boot 观察者模式:打造松耦合事件驱动应用程序

掌握 Spring Boot 观察者模式&#xff1a;打造松耦合事件驱动应用程序 观察者模式是一种常用的设计模式&#xff0c;用于解决事件驱动编程中的问题。该模式定义了一对多的依赖关系&#xff0c;其中一个对象&#xff08;主题&#xff09;向一组依赖它的对象&#xff08;观察者&a…

供应商管理库存用什么软件

库存的管理是一个非常重要的话题&#xff0c;不管是企业还是个人&#xff0c;在日常工作中多多少少都会涉及到库存的管理&#xff0c;那么作为供应商&#xff0c;也是需要对库存进行管理的&#xff0c;因为需要对分销商进行出货&#xff0c;所以库存的有效管理非常重要。 供应商…

【cocos creator】2.4.0 import android.support.v4.app.ActivityCompat;失败的解决方案

时间是2024年5月&#xff0c;某cocos creator项目用的是2.4.0编辑器。需求是获取录音权限&#xff0c;需要import ActivityCompat。但是失败&#xff0c;提示Cannot resolve symbol app。 尝试了一些方案失败之后&#xff0c;决定升级cocos creator编辑器版本。升级到2.4.10。…

矿用光缆型号和规格

管道矿用光缆生产厂家&#xff0c;矿用光缆特点是什么&#xff0c;矿用通信光缆 矿用光缆 MGTS光缆的结构是将250 m光纤套入高模量材料制成的松套管中&#xff0c;松套管内填充防水化合物。缆芯的中心是一根金属加强芯&#xff0c;对于某些芯数的光缆来说&#xff0c;金属加强…

vue3 自定义国际化、elementPlus 国际化

自定义国际化 1. 引入 vue-i18n 插件 pnpm install vue-i18nnext 2. 页面添加语言文件目录&#xff0c;添加自定义的语言文件 3.语言目录里添加 index.ts&#xff0c; 内容如下 import { createI18n } from "vue-i18n";// 自定义语言文件 import zhCN from "…

灾备建设中虚拟机备份自定义数据块大小应用

灾备建设中&#xff0c;传输备份数据时&#xff0c;自定义数据块大小可以帮助优化数据传输和存储效率。 确定数据块大小&#xff0c;首先&#xff0c;需要确定合适的数据块大小。这可以根据备份数据量和网络带宽来决定。通常情况下&#xff0c;较小的数据块可以更好地适应网络…

Python构建网络控制和管理应用程库之使用详解

概要 POX是一种广泛使用的Python开发工具,主要用于构建网络控制和管理应用程序。作为一个灵活的软件平台,POX支持快速开发网络通信协议,尤其是在软件定义网络(SDN)领域中得到了广泛应用。本文将全面介绍POX库的安装、主要特性、基本与高级功能,并结合实际应用场景,展示…

惊叹!蚓链数字化平台:助你拥有数据能力,打造数字资产!

在数字时代&#xff0c;数据能力成为打造宝贵数字资产的关键&#xff01;而蚓链数字化平台&#xff0c;就是那个能让你实现这一目标的神奇工具&#xff01;想知道它是如何做到的吗&#xff1f;让我们一起来揭开这个谜底吧&#xff01; 1.蚓链数字化平台为你提供丰富的数据资源&…

金字塔原理:让你的思维与表达更有魅力 (1)

一、为什么我们需要金字塔原理&#xff1f; 想象一下&#xff0c;你正在参加一个重要的商务会议&#xff0c;需要向一群专业人士展示你的项目计划。你站在台上&#xff0c;面对着数十双渴望知识的眼睛&#xff0c;你心中充满了激情和期待。但是&#xff0c;当你开始讲话时&…

2024年亚洲图像处理趋势会议(ATIP 2024)即将召开!

2024年亚洲图像处理趋势会议&#xff08;ATIP 2024&#xff09;将于2024年10月13-15日在英国伦敦举行。解码图像&#xff0c;解码未来&#xff01;ATIP 2024旨在汇聚亚洲乃至全球图像处理领域的专家学者&#xff0c;共同探讨图像处理技术的最新发展趋势、前沿应用以及面临的挑战…

某东抢购某台脚本——高成功率

某东抢购某台脚本——高成功率 小白操作-仅供学习参考 说明 这段代码主要关联了许多网络请求和对应的业务逻辑处理&#xff0c;用于处理与一个名为“茅台商城”的应用相关的网络操作。主要功能和关键组件的详细说明如下&#xff1a; 全局变量和配置&#xff1a; 使用AES加密…

快速配置 Nginx 来实现 GPT 流式传输

目录 1. Nginx 参考配置2. Nginx 核心参数3. 其他参数 场景&#xff1a;代理 ChatGPT、代理各种 GPT 工具套壳等。 1. Nginx 参考配置 支持 GPT 流式访问的配置如下&#xff0c;请根据实际需求适当取舍即可&#xff1a; server {listen 80;server_name chat.test.com; # 绑…

信号处理SCI期刊,中科院2区,专业性强,审稿速度快!

一、期刊名称 Signal Processing 二、期刊简介概况 期刊类型&#xff1a;SCI 学科领域&#xff1a;信号处理 影响因子&#xff1a;4.4 中科院分区&#xff1a;2区 出版方式&#xff1a;订阅模式/开放出版 版面费&#xff1a;选择开放出版需支付$3300 三、期刊征稿范围 …

蛋白胨(Peptone)主要应用于微生物发酵领域 我国进口量持续增长

蛋白胨&#xff08;Peptone&#xff09;主要应用于微生物发酵领域 我国进口量持续增长 蛋白胨&#xff08;Peptone&#xff09;是一种有机化合物&#xff0c;分子式为C5H9NO2。蛋白胨外观呈淡黄至棕黄色粉剂&#xff0c;含有肉香气味&#xff0c;易溶于水&#xff0c;不溶于乙醚…