网络编程入门-实现服务器与客户端通讯

news2025/1/23 17:43:27

概念学习

TCP概念:
TCP(Transmission Control Protocol)协议指的是传输控制协议,是一个面向连接的传输协议,他是一个能提供高可靠性的通信协议,所谓高可靠性指的是数据无丢失、数据无误、数据无失序、数据无重到达。(打电话)
适用场景:
适用于对传输质量要求较高,以及传输大量数据的通信。
在需要传输可靠数据的场合通常会选择使用TCP通信协议。
比如QQ/微信/支付宝等通信软件的账户登录和支付相关功能是通常采用可靠的TCP通信协议来实现。
UDP概念:
UDP(User Datagram Protocol)指的是用户数据报协议,是一种不可靠无连接的协议,在数据发送前,不需要提前建立连接,所以可以更高效地传输数据。(发邮件)

适用场景:
发送小尺寸地数据(例如对DNS服务器进行地址查询或路游器更新路由表)
在收到数据,给出应答比较困难地网络中适用UDP(比如无线网络)
适用于广播/组播式通信。
QQ/微信等即时通信软件地点对点文件通讯以及音视频通话时。
流媒体、VoIOP、IPTV等网络多媒体服务中(直播间)

 相关API函数

UDP相关API

创建一个待连接套接字socket

1 #include <sys/socket.h>
2 int socket(int domain, int type, int protocol);
3 参数:
4 domain:域。
5 AF_INET/PF_INET: 网际协议
6 AF_UNIX/PF_UNIX:本地协议,可写成 AF_LOCAL/PF_LOCAL

7 type:类型。
8 SOCK_STREAM:流式套接字 TCP协议
9 SOCK_DGRAM:数据报套接字 UDP协议

10 protocol:协议。
11 一般为 0

12 返回值:
13 成功:待连接套接字
14 失败:-1

绑定地址: 

#include <sys/types.h>
#include <sys/socket.h>

1 int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
2 参数:
3 sockfd:待连接套接字
4 addr:包含本地地址(IP+PORT)的通用地址结构体的指针
5 addrlen:地址结构体大小

6 返回值:
7 成功:0
8 失败:-1

 地址结构体

我们要么用IPV4或IPV6,因为直接使用通用结构体来配置不方便,再将IPV4或IPV6的结构体强转为通用结构体。

 struct sockaddr // 通用IP信息结构体
 {
 sa_family_t sa_family;
 char sa_data[14];
 }

 struct sockaddr_in // IPV4地址结构体
 {
 u_short sin_family;// 地址族(网际协议/本地协议)
 u_short sin_port;// 端口(65000 以上)
 struct in_addr sin_addr;// IPV4 地址(ifconfig可以查看)
 char sin_zero[8];//暂时不管不知道干嘛的
 };

 struct in_addr // IP地址结构体
 {
 in_addr_t s_addr;// 无符号 32 位网络地址
 };

发送数据到UDP:

1 ssize_t sendto(int sockfd, const void *buf, size_t len, int flags,
2 const struct sockaddr *dest_addr, socklen_t addrlen);
3 参数:
4 sockfd:UDP 套接字
5 buf:即将发送的数据
6 len:数据的长度
7 flags:发送标志,与函数 send 的 flags 完全一致
8 dest_addr:对端网络地址
9 addr_len:地址长度
10 返回值:
11 成功:已发送字节数
12 失败:-1

从UDP中接收数据:

1 ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags,
2 struct sockaddr *src_addr, socklen_t *addrlen);
3 参数:
4 sockfd:UDP 套接字
5 buf:储存数据缓冲区
6 len:缓冲区大小
7 flags:接收标志,与函数 send 的 flags 完全一致
8 src_addr:对端网络地址
9 addrlen:地址长度
10 返回值:
11 成功:已接收字节数
12 失败:返回-1

UDP通信过程:

程序实现

UDP通讯

服务端

服务端实现思路:就好比寄邮件

第一步:我们需要一个放邮件的邮箱(创建套接字,socket()函数)

第二步:我们要标注将这个邮件发往什么地方(用IPV4地址结构体标注这个套接字的去向信息比如:IP地址、端口号、那种协议)

第三步:将邮件和标注信息绑定起来(bind()函数)

第四部:将邮件进行发送 (recvfrom()函数)

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <unistd.h>
#include <arpa/inet.h>  //这个结构体包含了地址结构体的声明
#include <netinet/in.h>




int main()
{
//1、创建信箱(套接字)
int socket_fd = socket(AF_INET, SOCK_DGRAM, 0);
if(-1 == socket_fd)
{
    perror("socket err");  
    return -1;                  
}

//2、设置信箱地址和端口号
//设置信箱地址
/*
 struct sockaddr_in // IPV4地址结构体
 {
 u_short sin_family;// 地址族(网际协议/本地协议)
 u_short sin_port;// 端口(65000 以上)
 struct in_addr sin_addr;// IPV4 地址(ifconfig可以查看)
 char sin_zero[8];//暂时不管不知道干嘛的
 };
 */
struct sockaddr_in my_sockaddr = {0};
my_sockaddr.sin_family = AF_INET;
my_sockaddr.sin_port = htons(65000);//用函数将主机字节序转换为网络字节序才能进行茶传输
//in_addr_t inet_addr(const char *cp);
my_sockaddr.sin_addr.s_addr = inet_addr("192.168.80.128");

int len = sizeof(struct sockaddr_in);
//3.把设置好的信息与信箱进行绑定
int ret_val = bind(socket_fd, (struct sockaddr *)&my_sockaddr, len);
if(-1 == ret_val)
{
    perror("bind error");
    return -1;
}
//4.等待客户端来信
//先让一直等待接受
char * msg = calloc(128,1);//存储接收到的信息
struct sockaddr_in src_addr;//将接收到的套接字存放在此处
while(1)
{
 ssize_t ret_val = recvfrom(socket_fd, msg, 128, 0,
                  (struct sockaddr *)&src_addr, &len);
                  if(-1 == ret_val)
                  {
                    perror("recvfrom error");
                    continue;
                  }
                  else
                  {
                    printf("recvfrom succeed,msg:%s\n",msg);
                    //如果需要打印别的信息src_addr,这个结构体里将数据进行转换显示
                    printf("addr:%s\n",inet_ntoa( src_addr.sin_addr ));//显示发送者的IP地址
                     printf("addr:%s\n",inet_ntoa( src_addr.sin_addr ));
                  }
}
    return 0;
}

客户端

客户端不要将信件和信件的去向信息进行绑定,客户端是发送信息

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <unistd.h>
#include <arpa/inet.h>  //这个结构体包含了地址结构体的声明
#include <netinet/in.h>




int main()
{
//1、创建信箱(套接字)
int socket_fd = socket(AF_INET, SOCK_DGRAM, 0);
if(-1 == socket_fd)
{
    perror("socket err");  
    return -1;                  
}

//2、设置信箱地址和端口号
//设置信箱地址
/*
 struct sockaddr_in // IPV4地址结构体
 {
 u_short sin_family;// 地址族(网际协议/本地协议)
 u_short sin_port;// 端口(65000 以上)
 struct in_addr sin_addr;// IPV4 地址(ifconfig可以查看)
 char sin_zero[8];//暂时不管不知道干嘛的
 };
 */

struct sockaddr_in my_sockaddr = {0};
my_sockaddr.sin_family = AF_INET;
my_sockaddr.sin_port = htons(65000);//用函数将主机字节序转换为网络字节序才能进行茶传输
//in_addr_t inet_addr(const char *cp);
my_sockaddr.sin_addr.s_addr = inet_addr("192.168.80.128");

int len = sizeof(struct sockaddr_in);

//4.等待客户端来信
//先让一直发送
char * msg = calloc(128,1);
int ret_val = -1;

while(1)
{
                        printf("请输入的消息为:\n");
                        fgets(msg,128,stdin);
  ret_val = sendto(socket_fd, msg, strlen(msg), 0,
                  (struct sockaddr *)&my_sockaddr, len);
                  if(-1 == ret_val)
                  {
                    perror("sendto error");
                    continue;
                  }
                  else
                  {
                    printf("sendto succeed %d byte! \n",ret_val);
                  }
}
    return 0;
}

实验结果

两个端口之间可以进行通讯 

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

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

相关文章

【Linux】万字解读<进程控制>:创建&中止&等待&替换

前言 大家好吖&#xff0c;欢迎来到 YY 滴Linux系列 &#xff0c;热烈欢迎&#xff01; 本章主要内容面向接触过Linux的老铁 主要内容含&#xff1a; 欢迎订阅 YY滴C专栏&#xff01;更多干货持续更新&#xff01;以下是传送门&#xff01; YY的《C》专栏YY的《C11》专栏YY的《…

2024年【甘肃省安全员C证】报名考试及甘肃省安全员C证考试总结

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2024年甘肃省安全员C证报名考试为正在备考甘肃省安全员C证操作证的学员准备的理论考试专题&#xff0c;每个月更新的甘肃省安全员C证考试总结祝您顺利通过甘肃省安全员C证考试。 1、【多选题】下列选用起重机钢丝绳时…

2 模拟——258. 各位相加 ★

2 模拟 258. 各位相加 ★ 给定一个非负整数 num&#xff0c;反复将各个位上的数字相加&#xff0c;直到结果为一位数。返回这个结果。 示例 1: 输入: num 38 输出: 2 解释: 各位相加的过程为&#xff1a; 38 --> 3 8 --> 11 11 --> 1 1 --> 2 由于 2 是一位…

RK3562 NPU供电要求

在《RK3562 NPU跑飞问题处理》文档中,有提及PWM_NPU网络对应的IO域电平,之前使用1.8V(PMUIO1电平),对应可以测量到VDD_NPU_P的电压为0.8V(上电后不工作状态),而最近硬件配置PMUIO1改为了3.3V,VDD_NPU_P的电压为0.6V,虽然部分AI模型能跑起来,但也存在NPU识别出错的情…

基于人工智能的实时交通监控系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 实时交通监控系统通过人工智能技术对交通流量进行监测和分析&#xff0c;能够帮助城市管理者优化交通流、减少拥堵、提升道路安全。本…

xilinx sdk退出Debug模式返回C开发布局模式

点击甲壳虫进入Debug窗口模式&#xff0c;退出方法是在最右上角quick access旁点击窗口布局的格子(open perspective)点击第一个default即可回到原先布局。

【python篇】——python基础语法一篇就能明白,快速理解

前言&#xff1a;本文章是在已经学习了C语言之后作者角度下进行书写的一篇关于python当中基础的语法说明。 文章目录 快速深入理解python当中的语法基本数据类型算数运算符类型的查看与转换 变量的输入与输出条件语句比较运算符和逻辑运算符if、elif、else三目运算符 循环语句w…

Qt:自制白噪声播放器

前言 由于本人觉得听着白噪声学习效果才会更佳&#xff0c;所以做了一个白噪声播放器。先看效果吧 我在里面添加了一些音乐 运行视频 whiteMusicDemo 中间区域原本想画个图像的&#xff0c;但是不知道要画啥&#xff0c;就搞了张图片贴上去&#xff0c;如果有想法的朋友可以…

《Attention Is All You Need》论文导读

版权声明 本文原创作者:谷哥的小弟作者博客地址:http://blog.csdn.net/lfdfhl论文背景 《Attention Is All You Need》这篇具有里程碑意义的论文,彻底改变了自然语言处理(NLP)的研究和应用格局。在此之前,循环神经网络(RNN)及其变体,如长短期记忆网络(LSTM),是处理…

首例开源的自动驾驶混合运动规划框架,手握“规划可解释”和“决策准确”两张王牌!

导读&#xff1a; 本文开发了一种新的混合运动规划方法&#xff0c;将环境和预测信息集成在Frenet坐标系中&#xff0c;提升了运动规划能力。本文将传统运动规划算法的可预测性和稳定性与RL的动态适应性相结合&#xff0c;从而形成了一个能够有效管理复杂情况并适应不断变化的环…

C#高级:递归3-根据ID连续递归生成一颗递归树

目录 一、需求&#xff1a; 二、实现代码 三、递归代码 四、思考 一、需求&#xff1a; 给小明一家生成族谱树 二、实现代码 using Newtonsoft.Json;class Person {public int Id { get; set; }public int? ParentID { get; set; }public string Name { get; set; } }c…

四数相加 II--力扣454

四数相加 II 题目思路C代码 题目 思路 我们需要统计元组的个数&#xff0c;并且不需要排序和去重&#xff0c;所以选择哈希表unordered_map。 要使得abcd0&#xff0c;我们首先利用map在前两个数组中统计ab的值以及该值出现的次数。 接下来我们去后两个数组中查找0-(cd)&…

每日一练:除自身以外数组的乘积

一、题目要求 给你一个整数数组 nums&#xff0c;返回 数组 answer &#xff0c;其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法&#xff0c;且在…

windows手工杀毒-寻找可疑进程之句柄

上篇回顾&#xff1a;windows手工杀毒-寻找可疑进程之内存-CSDN博客 上篇中我们介绍了如果通过进程的内存分析进程是否是可疑进程&#xff0c;主要是通过查看是否有可写可执行的内存页。也可以通过查看内存内容&#xff0c;看是否是可疑内容&#xff0c;不过这个可能需…

如何取消密码?打印加密的PDF文件?

在日常生活和工作中&#xff0c;我们时常会遇到需要处理加密PDF文件的情况。这些文件可能包含敏感信息&#xff0c;如合同、报告或私人文档&#xff0c;因此被设置了密码保护。然而&#xff0c;有时我们出于工作需要或其他原因&#xff0c;需要打印这些加密的PDF文件。本文将详…

管道检测机器人市场前景:预计2030年全球市场规模将达到18.9亿美元

用于检查管道内堆积的残留物的机器人被称为管道内检查机器人。这种机器人有能力从地面向机器人的控制器发送视频反馈信息。通过这种方式&#xff0c;用户可以验证管道的实际状况&#xff0c;也可以测量管道壁上的沉积物厚度。 据QYResearch调研团队最新报告“全球管道检测机器人…

苹果手机照片被删除?如何通过不同的方法来恢复照片

手机已经成为我们生活中不可或缺的一部分&#xff0c;它不仅仅是通讯工具&#xff0c;更是我们记录生活点滴的重要工具之一。然而&#xff0c;正如其他任何设备一样&#xff0c;iPhone上存储的照片有时也会不小心被删除或丢失。 别担心&#xff0c;即使你误删了重要的照片&…

未来的去中心化网络:Web3与AI的深度融合探讨

在数字技术的快速发展下&#xff0c;Web3和人工智能&#xff08;AI&#xff09;正逐步成为未来互联网的核心支柱。Web3作为一种去中心化的网络架构&#xff0c;致力于重塑互联网的基本结构&#xff0c;而AI则通过智能化技术提升了数据处理和决策的能力。二者的深度融合不仅推动…

数学建模笔记—— 模糊综合评价

数学建模笔记—— 模糊综合评价 模糊综合评价1. 模糊数学概述2. 经典集合和模糊集合的基本概念2.1 经典集合2.2 模糊集合和隶属函数1. 基本概念2.模糊集合的表示方法3. 模糊集合的分类4. 隶属函数的确定方法 3. 评价问题概述4. 一级模糊综合评价模型典型例题 5. 多层次模糊综合…

系统分析师8:项目管理

文章目录 1 内容提要2 范围管理3 时间管理3.1 时间管理-关键路径法3.1.1 时间管理-前导图法&#xff08;单代号网络图&#xff0c;PDM&#xff09;3.1.2 时间管理-箭线图法(双代号网络图&#xff0c;ADM) 4 时间管理-甘特图&#xff08;Gantt&#xff09;5 成本管理6 软件质量管…