Linux C语言实现UDP的发送和接收

发送端实现:U1.c

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

int main(int argc, char** argv)
{
    // 第一步:创建套接字
    // UDP 协议使用数据报式套接字,即套接字类型为 SOCK_DGRAM
    int sock = socket(AF_INET, SOCK_DGRAM, 0);

    if(sock == -1)
    {
        perror("socket");
        return 1;
    }


    // 第二步:绑定地址(IP + Port)
    struct sockaddr_in myaddr;
    myaddr.sin_family = AF_INET;
    myaddr.sin_addr.s_addr = inet_addr("127.0.0.1");
    myaddr.sin_port = htons(8888);

    if(bind(sock, (struct sockaddr*)&myaddr, sizeof(myaddr)) == -1)
    {
        perror("bind");
        return 1;
    }

    // 第三步:收发数据
    
    // 发送数据
    
    // 指定接收方地址   
    struct sockaddr_in dst_addr;
    dst_addr.sin_family = AF_INET;
    dst_addr.sin_addr.s_addr = inet_addr(argv[1]);//命令行输入接收方IP
    dst_addr.sin_port = htons(atoi(argv[2]));//命令行输入端口号

    // 指定数据内容
    char msg[128];
    int ret;

    while(1)
    {
        // 发送出去
        sprintf(msg, "hello, i am world");
        ret = sendto(sock, msg, strlen(msg), 0, (struct sockaddr*)&dst_addr, sizeof(dst_addr));
        sleep(1);
        if(ret == -1)
        {
            perror("sendto");
        }

    }
   
    // 第四步:关闭套接字
    close(sock);
    
    return 0;
} 

接收方实现:U2.c

#include <stdio.h>                                                                                                                                                                                                                               
#include <time.h>
#include <string.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <arpa/inet.h>
#include <unistd.h>

int main()
{
    // 第一步:创建套接字
    // UDP 协议使用数据报式套接字,即套接字类型为 SOCK_DGRAM
    int sock = socket(AF_INET, SOCK_DGRAM, 0);

    if(sock == -1)
    {
        perror("socket");
        return 1;
    }


    // 第二步:绑定地址(IP + Port)
    struct sockaddr_in myaddr;
    myaddr.sin_family = AF_INET;
    myaddr.sin_addr.s_addr = INADDR_ANY;
    myaddr.sin_port = htons(9999);

    if(bind(sock, (struct sockaddr*)&myaddr, sizeof(myaddr)) == -1)
    {
        perror("bind");
        return 1;
    }


    // 第三步:收发数据
    
    char msg[100];
    int ret;
    

    // 接收数据
    
    //connect(sock, (struct sockaddr*)&addr, sizeof(addr));

    while(1)
    {   
        struct sockaddr_in addr;
        socklen_t len  = sizeof(addr);
        // 调用 recvfrom 函数时如果当前没有任何数据包,它会阻塞当前线程,直到成功接收到一个数据包或出错。出错时返回 -1,成功接收到一个数据包时返回接收到的字节数,如果收到空数据包,返回值为 0
    
        ret = recvfrom(sock, msg, sizeof(msg) - 1, 0, (struct sockaddr*)&addr, &len);
    
        if(0 < ret)
        {
            msg[ret] = '\0';
            printf("\n%s:%d说:%s\n", inet_ntoa(addr.sin_addr), ntohs(addr.sin_port), msg);
        }
        
    }

// 第四步:关闭套接字
    close(sock);

    return 0;
}

编译:gcc U1.c -o U1

           gcc U2.c -o U2

运行:./U1 192.xxx.xxx.xxx(IP地址) 9999(端口号,两程序需一致)

            ./U2

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
UDP服务端的收发主要需要使用Linux下的socket编程。 以下是一个简单的示例代码,实现UDP服务端的收发: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/socket.h> #include <arpa/inet.h> #define BUF_SIZE 1024 void error_handling(char *message); int main(int argc, char *argv[]) { int serv_sock; char message[BUF_SIZE]; int str_len, addr_size; struct sockaddr_in serv_addr, clnt_addr; if (argc != 2) { printf("Usage : %s <port>\n", argv[0]); exit(1); } serv_sock = socket(PF_INET, SOCK_DGRAM, 0); if (serv_sock == -1) { error_handling("UDP socket creation error"); } memset(&serv_addr, 0, sizeof(serv_addr)); serv_addr.sin_family = AF_INET; serv_addr.sin_addr.s_addr = htonl(INADDR_ANY); serv_addr.sin_port = htons(atoi(argv[1])); if (bind(serv_sock, (struct sockaddr *) &serv_addr, sizeof(serv_addr)) == -1) { error_handling("bind() error"); } while (1) { addr_size = sizeof(clnt_addr); str_len = recvfrom(serv_sock, message, BUF_SIZE, 0, (struct sockaddr *) &clnt_addr, &addr_size); if (str_len < 0) { error_handling("recvfrom() error"); } printf("Received message from %s:%d\n", inet_ntoa(clnt_addr.sin_addr), ntohs(clnt_addr.sin_port)); printf("Message: %s\n", message); if (sendto(serv_sock, message, str_len, 0, (struct sockaddr *) &clnt_addr, sizeof(clnt_addr)) == -1) { error_handling("sendto() error"); } } close(serv_sock); return 0; } void error_handling(char *message) { fputs(message, stderr); fputc('\n', stderr); exit(1); } ``` 运行时需要输入监听的端口号作为参数,例如: ``` $ ./udp_server 1234 ``` 运行后,服务端会不断接收客户端发送的消息,并将其原封不动地发送回去。可以使用 `netcat` 命令模拟客户端向服务端发送消息: ``` $ echo "Hello, UDP server" | nc -4u localhost 1234 ``` 服务端会输出如下信息: ``` Received message from 127.0.0.1:xxxxx Message: Hello, UDP server ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值