UDP socket编程示例

服务端:

cpp 复制代码
#include <iostream>
#include <cstring>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>

const int BUFFER_SIZE = 1024;

//TODO 使用多线程处理连接

int main()
{
    int sockfd = socket(AF_INET, SOCK_DGRAM, 0);
    if (sockfd < 0)
    {
        std::cerr << "Error opening socket" << std::endl;
        return 1;
    }
    struct sockaddr_in servaddr {};
    servaddr.sin_family = AF_INET;
    servaddr.sin_addr.s_addr = INADDR_ANY;
    servaddr.sin_port = htons(6868);

    if (bind(sockfd, (const struct sockaddr*)&servaddr, sizeof(servaddr)) < 0)
    {
        std::cerr << "Error on binding" << std::endl;
        return 1;
    }
    std::cout << "UDP server up and running on port 6868" << std::endl;

    char buffer[BUFFER_SIZE];
    struct sockaddr_in clientaddr;
    socklen_t len = sizeof(clientaddr);

    while(true)
    {
        ssize_t recvbytes = recvfrom(sockfd, buffer, BUFFER_SIZE, 0, (struct sockaddr*)&clientaddr, &len);
        if (recvbytes < 0)
        {
            std::cerr << "Error receiving message" << std::endl;
            return 1;
        }
        buffer[recvbytes] = '\0';
        std::cout << "Received message:" << buffer << " from " << inet_ntoa(clientaddr.sin_addr) << std::endl;

        if (sendto(sockfd, buffer, recvbytes, 0, (const struct sockaddr * )&clientaddr, len) < 0)
        {
            std::cerr << "Error sending message" << std::endl;
            return 1;
        }
    }
    close(sockfd);
}

客户端:

cpp 复制代码
#include <iostream>
#include <string>
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <unistd.h>

const int BUFFER_SIZE = 1024;

int main() {
    // Create a UDP socket
    int sockfd = socket(AF_INET, SOCK_DGRAM, 0);
    if (sockfd < 0) {
        std::cerr << "Error opening socket" << std::endl;
        return 1;
    }

    // Set up the server address structure
    struct sockaddr_in servaddr {};
    servaddr.sin_family = AF_INET; // IPv4
    servaddr.sin_addr.s_addr = inet_addr("127.0.0.1"); // Server IP
    servaddr.sin_port = htons(6868); // Port

    // Message to be sent
    std::string message = "Hello, Server!";

    // Send the message to the server
    if (sendto(sockfd, message.c_str(), message.size(), 0, (struct sockaddr *)&servaddr, sizeof(servaddr)) < 0) {
        std::cerr << "Error sending message" << std::endl;
        return 1;
    }

    std::cout << "Message sent to server." << std::endl;

    // Receive the message from the server
    char buffer[BUFFER_SIZE];
    struct sockaddr_in fromaddr;
    socklen_t fromlen = sizeof(fromaddr);

    ssize_t recvbytes = recvfrom(sockfd, buffer, BUFFER_SIZE, 0, (struct sockaddr *)&fromaddr, &fromlen);
    if (recvbytes < 0) {
        std::cerr << "Error receiving message" << std::endl;
        return 1;
    }

    // Null-terminate the buffer
    buffer[recvbytes] = '\0';

    // Print the received message
    std::cout << "Received message: " << buffer << " from " << inet_ntoa(fromaddr.sin_addr) << std::endl;

    // Close the socket
    close(sockfd);

    return 0;
}

区别:

  1. 绑定(Bind):

    • 服务端 :通常需要调用bind()函数来绑定到一个特定的端口,这样它才能监听发往该端口的数据。在示例中,服务端绑定到端口8888。
    • 客户端 :不需要绑定到一个端口,因为它是主动发起连接的一方。在示例中,客户端没有调用bind(),所以它会使用一个临时的源端口。
  2. 接收和发送数据:

    • 服务端 :使用recvfrom()函数来接收客户端发送的消息,这个函数可以获取发送方的地址信息。
    • 客户端 :使用sendto()发送消息,使用recvfrom()接收服务端的回显消息。
  3. 地址信息:

    • 服务端:需要一个服务器地址结构来存储其绑定的地址信息,包括IP地址和端口号。
    • 客户端:需要一个服务器地址结构来指定消息发送的目标地址和端口号。
  4. 网络编程模型:

    • 服务端:通常设计为可以持续运行,处理来自不同客户端的请求。
    • 客户端:可能设计为发送一次请求后关闭,或者根据需要发送多次请求。
  5. 并发处理:

    • 服务端:在实际应用中,可能需要处理多个客户端的并发连接,这可能涉及到多线程或多进程的使用。
    • 客户端:通常不需要处理并发,除非一个客户端需要同时与多个服务端通信。

相同点:

  1. 关闭连接(Close):

    • 服务端和客户端 :在完成数据传输后,都会调用close()函数来关闭socket。
  2. 错误处理:

    • 服务端和客户端:都需要对可能发生的错误进行处理,如socket创建失败、绑定失败、发送/接收失败等。
相关推荐
2501_9160137413 分钟前
用Fiddler中文版抓包工具掌控微服务架构中的接口调试:联合Postman与Charles的高效实践
websocket·网络协议·tcp/ip·http·网络安全·https·udp
xkroy2 小时前
网络协议概念与应用层
网络
筏.k2 小时前
C++ 网络编程(14) asio多线程模型IOThreadPool
网络·c++·架构
00后程序员张2 小时前
调试 WebView 接口时间戳签名问题:一次精细化排查和修复过程
websocket·网络协议·tcp/ip·http·网络安全·https·udp
门思科技2 小时前
设计可靠 LoRaWAN 设备时需要考虑的关键能力
运维·服务器·网络·嵌入式硬件·物联网
小锋学长生活大爆炸2 小时前
【知识】RPC和gRPC
服务器·网络协议·rpc
小高不会迪斯科3 小时前
MIT 6.824学习心得(2) 浅谈多线程和RPC
网络·网络协议·rpc
前端小巷子3 小时前
跨域问题解决方案:CORS(跨域资源共享)
前端·网络协议·面试
清醒的兰3 小时前
Qt 基于TCP套接字编程
网络·qt·tcp
程序猿追4 小时前
免费版安全性缩水?ToDesk、TeamViewer、向日葵、网易UU远程访问&隐私防护测评
服务器·网络·科技·teamviewer