Linux网络编程之---UDP

一.UDP通信流程

1.server:

1.创建一个socket()

2.bind()

3.recvfrom()

4.sendto()

5.close()

2.client:

1.socket

2.sendto()

3.recvfrom()

4.close()

二.涉及到的api

ssize_t sendto(int sockfd, const void *buf, size_t len, int flags,

const struct sockaddr *dest_addr, socklen_t addrlen);

-参数:

  • sockfd : 通信的fd

  • buf : 要发送的数据

  • len : 发送数据的长度

  • flags : 0

  • dest_addr : 通信的另外一端的地址信息

  • addrlen : 地址的内存大小

ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags,

struct sockaddr *src_addr, socklen_t *addrlen);

-参数:

-sockfd:通信的fd

-buf:接收数据的数组

-len:数组的大小

-flags:0

-src_addr : 用来保存另外一段的地址信息,不需要指定为NULL

-socklen_t:地址的内存大小

三.udp服务端和客户端代码实现

1.服务端

#include <stdio.h>
#include <arpa/inet.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>


int main()
{
    int udp_sockfd = socket(AF_INET,SOCK_DGRAM,0);
    if(udp_sockfd == -1)
    {
        perror("socket");
        exit(-1);
    }
    struct sockaddr_in server;
    server.sin_family = AF_INET;
    server.sin_addr.s_addr = INADDR_ANY;
    server.sin_port = htons(8000);
    int opt = 1;
    setsockopt(udp_sockfd,SOL_SOCKET,SO_REUSEPORT,(const void*)&opt,sizeof(opt));
    if(bind(udp_sockfd,(const struct sockaddr*)&server,sizeof(server)) == -1)
    {
        perror("bind");
        exit(-1);
    }
    char recvbuff[1024];
    struct sockaddr_in clienaddr;
    int len = sizeof(clienaddr);
    char client_ip[16] = {0};
    unsigned int client_port = 0;
    while(1)
    {
        memset(recvbuff,0,sizeof(recvbuff));
        //接收数据
        int num = recvfrom(udp_sockfd,recvbuff,sizeof(recvbuff),0,
                (struct sockaddr*)&clienaddr,&len);
        if(num == -1)
        {
            perror("recvfrom");
            exit(-1);
        }
        printf("recv data:%s,client ip : %s, client port : %d\n",recvbuff,
                inet_ntop(AF_INET,(const void*)&clienaddr.sin_addr.s_addr,client_ip,sizeof(client_ip)),
                ntohs(clienaddr.sin_port));
        
        //发送数据
        sendto(udp_sockfd,recvbuff,strlen(recvbuff)+1,0,
                (const struct sockaddr*)&clienaddr,sizeof(clienaddr));
    }
    close(udp_sockfd);
    return 0;
}

2.客户端

#include <stdio.h>
#include <arpa/inet.h>
#include <string.h>
#include <unistd.h>
#include <stdlib.h>


int main()
{
    int udp_sockfd = socket(AF_INET,SOCK_DGRAM,0);
    if(udp_sockfd == -1)
    {
        perror("socket");
        exit(-1);
    }

    char recvbuff[1024];
    char *sendbuf;
    //服务器地址信息
    struct sockaddr_in saddr;
    saddr.sin_family = AF_INET;
    saddr.sin_addr.s_addr = inet_addr("127.0.0.1");
    saddr.sin_port = htons(8000);
    int len = sizeof(saddr);
    while(1)
    {
        printf("亲爱的用户,请您输入你想要发送给服务器的信息:");
        scanf("%s",sendbuf);
        //发送数据
        sendto(udp_sockfd,sendbuf,strlen(sendbuf)+1,0,
                (const struct sockaddr*)&saddr,sizeof(saddr));

        memset(recvbuff,0,sizeof(recvbuff));
        //接收数据
        int num = recvfrom(udp_sockfd,recvbuff,sizeof(recvbuff),0,
                NULL,NULL);
        if(num == -1)
        {
            perror("recvfrom");
            exit(-1);
        }
        printf("接收到回射信息:%s\n",recvbuff);
        
    }
    close(udp_sockfd);
    return 0;
}
相关推荐
qq_2430507944 分钟前
dnsmap:DNS枚举 详细完整教程 Kali Linux&Termux入门教程 黑客渗透测试 信息收集
linux·网络·安全·web安全·网络安全·系统安全·ddos
芒果爱编程1 小时前
MCU、ARM体系结构,单片机基础,单片机操作
开发语言·网络·c++·tcp/ip·算法
小春学渗透3 小时前
DAY168内网对抗-基石框架篇&单域架构&域内应用控制&成员组成&用户策略&信息收集&环境搭建
网络·安全·架构·内网攻防
Pou光明4 小时前
1_linux系统网络性能如何优化——几种开源网络协议栈比较
linux·运维·网络·网络协议·开源
路-buan4 小时前
华为eNSP:VRRP的主备备份
网络·华为·智能路由器
feing.4 小时前
路由介绍.
网络
Tony聊跨境4 小时前
如何绕过IP禁令
网络·网络协议·tcp/ip·智能路由器·ip
C++忠实粉丝5 小时前
计算机网络之NAT、代理服务、内网穿透、内网打洞
网络·c++·网络协议·计算机网络·http·智能路由器
TianyaOAO5 小时前
inmp+discuz论坛
linux·运维·服务器
qq_254674415 小时前
华为 生产网解决方案,加速制造业数字化转型
网络