LINUX【网络编程】UDP程序recvfrom接收数据

2024-04-14 13:20

本文主要是介绍LINUX【网络编程】UDP程序recvfrom接收数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一,代码

#include <stdio.h>

#include <sys/socket.h> //socket函数

#include <netinet/in.h> //struct sockaddr_in结构体

#include <string.h>     //memset跟strlen

#include <arpa/inet.h>  //bind函数

#include <unistd.h>     //close函数

int main(int argc, const char *argv[])

{

    int sockfd = socket(AF_INET, SOCK_DGRAM, 0); // include<sys/socket.h>

    if (sockfd < 0)

    {

        perror("socket");

        return 0;

    }

    struct sockaddr_in my_addr;                  // #include<netinet/in.h>

    memset(&my_addr, 0, sizeof(my_addr));        // 初始化

    my_addr.sin_family = AF_INET;                // IPV4

    my_addr.sin_port = htons(9000);              // 端口号

    my_addr.sin_addr.s_addr = htonl(INADDR_ANY); // 通配地址,发送者主机地址

    int ret = bind(sockfd, (const struct sockaddr *)&my_addr, sizeof(my_addr));

    if (ret < 0)

    {

        perror("bind");

        return 0;

    }

    // recvfrom接收数据

    while (1)

    {

        unsigned char buf1[1500] = ""; // 最大1500

        struct sockaddr_in from_addr;

        socklen_t from_len = sizeof(from_addr);

        int len = recvfrom(sockfd, buf1, sizeof(buf1), 0, (struct sockaddr *)&from_addr, &from_len);

        if (len < 0)

        {

            perror("recvfrom");

            return 0;

        }

        char ip_str[16] = "";

        inet_ntop(AF_INET, &from_addr.sin_addr.s_addr, ip_str, 16); // 获取发送者的IP

        unsigned short port = ntohs(from_addr.sin_port);

        printf("TP:%s PORT:%hu 长度:%d 消息:%s\n", ip_str, port, len, buf1);

        close(sockfd);

        return 0;

    }

}

二,详细解读

此代码是一个简单的UDP服务器程序,用于接收来自客户端的数据并输出发送者的IP地址、端口号、数据长度以及数据内容。以下是对代码的详细解读:

  1. 引入必要的头文件:

    • stdio.h:标准输入输出库。
    • sys/socket.h:提供套接字函数的定义。
    • netinet/in.h:定义了 IP 地址结构 sockaddr_in 等。
    • string.h:提供字符串处理函数的定义。
    • arpa/inet.h:提供了一些 IP 地址转换函数的定义。
    • unistd.h:提供了一些系统调用函数的定义。
  2. 在 main 函数中:

    • 创建一个 UDP 套接字:int sockfd = socket(AF_INET, SOCK_DGRAM, 0);

      • 使用 socket 函数创建一个基于 IPv4 的 UDP 套接字。
      • 如果创建失败,会输出错误信息并返回。
    • 定义并初始化服务器的地址结构体 my_addr,并将套接字绑定到该地址:

      struct sockaddr_in my_addr;
      memset(&my_addr, 0, sizeof(my_addr));
      my_addr.sin_family = AF_INET;
      my_addr.sin_port = htons(9000);
      my_addr.sin_addr.s_addr = htonl(INADDR_ANY);
      int ret = bind(sockfd, (const struct sockaddr *)&my_addr, sizeof(my_addr));
      
      • 如果绑定失败,会输出错误信息并返回。
    • 在一个无限循环中接收数据并处理:

      • 使用 recvfrom 函数接收数据,并获取发送者的地址信息。
      • 将发送者的IP地址转换为字符串形式。
      • 打印发送者的IP地址、端口号、数据长度以及数据内容。
      • 关闭套接字并退出程序。
  3. 解析接收到的数据:

    • 接收到的数据存储在 buf1 中,数据的长度为 len
    • 使用 inet_ntop 函数将发送者的IP地址转换为字符串形式,存储在 ip_str 中。
    • 使用 ntohs 函数将端口号转换为主机字节序,并存储在 port 中。
  4. 打印接收到的信息:

    • 使用 printf 函数输出发送者的IP地址、端口号、数据长度以及数据内容。
  5. 关闭套接字并退出程序:

    • 在循环中,每次接收完数据后立即关闭套接字并返回,这会导致程序只能接收一次数据就退出。如果希望持续接收数据,需要将关闭套接字的部分移出循环。

总结:

  • 该程序是一个简单的UDP服务器,实现了接收来自客户端的数据并输出发送者的IP地址、端口号、数据长度以及数据内容的功能。
  • 如果需要持续接收数据,可以将关闭套接字的部分移到循环外,并添加适当的逻辑以维持服务器的运行。

这篇关于LINUX【网络编程】UDP程序recvfrom接收数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/903100

相关文章

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了

poj 2112 网络流+二分

题意: k台挤奶机,c头牛,每台挤奶机可以挤m头牛。 现在给出每只牛到挤奶机的距离矩阵,求最小化牛的最大路程。 解析: 最大值最小化,最小值最大化,用二分来做。 先求出两点之间的最短距离。 然后二分匹配牛到挤奶机的最大路程,匹配中的判断是在这个最大路程下,是否牛的数量达到c只。 如何求牛的数量呢,用网络流来做。 从源点到牛引一条容量为1的边,然后挤奶机到汇点引一条容量为m的边