使用udp绑定端口用来接收数据(二)

使用udp绑定端口用来接收数据

报一下环境:
win10 + pycharm(python3.7) + mNetAssist
就是win10从mNetAssist传数据到pycharm

话不多说,先放代码:

import socket


def main():

    # 创建一个套接字
    udp_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)

    # 绑定一个本地信息
    localaddr = ("", 7788)
    udp_socket.bind(localaddr)

    # 接收数据
    recv_data = udp_socket.recvfrom(1024)  # 1024 代表接收的最大字节数

    # 打印接收到的数据
    print(recv_data)

    # 关闭
    udp_socket.close()


if __name__ == "__main__":

    main()

但是这样接收到的数据是元组类型:
(b’hahaha’, (‘192.168.1.101’, 8080))
所以需要解析一下,其实也就是把元组切片(虽然只有两片),tuple[0]是接收的数据,tuple[1] 是发送方的ip以及port
打印的时候,要以字符串类型输出,所以把 tuple[1]str 强制类型转换一下, tuple[0]gbk 编码格式
代码如下:

import socket


def main():

    # 创建一个套接字
    udp_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)

    # 绑定一个本地信息
    localaddr = ("", 7788)
    udp_socket.bind(localaddr)  # 必须绑定自己电脑的ip以及port,其他的不行

    # 接受数据
    recv_data = udp_socket.recvfrom(1024)  # 1024 代表接收的最大字节数

    # recv_data 存储的是一个元组(接收到的数据,发送方的ip, port))
    recv_msg = recv_data[0]  # 存储接收的数据
    send_addr = recv_data[1]  # 存放发送方的地址信息

    # 打印接收到的数据
    print("%s:%s" %(str(send_addr), recv_msg.decode("GBK")))

    # 关闭
    udp_socket.close()


if __name__ == "__main__":

    main()

要想循环接收,加个 while True 就行,则代码如下:

import socket


def main():

    # 创建一个套接字
    udp_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)

    # 绑定一个本地信息
    localaddr = ("", 7788)
    udp_socket.bind(localaddr)  # 必须绑定自己电脑的ip以及port,其他的不行

    # 接受数据
    while True:

        recv_data = udp_socket.recvfrom(1024)  # 1024 代表接收的最大字节数

        # recv_data 存储的是一个元组(接收到的数据,发送方的ip, port))
        recv_msg = recv_data[0]  # 存储接收的数据
        send_addr = recv_data[1]  # 存放发送方的地址信息

        # 打印接收到的数据
        print("%s:%s" %(str(send_addr), recv_msg.decode("GBK")))

    # 关闭
    udp_socket.close()


if __name__ == "__main__":

    main()

注意事项

  • 1.以上代码中绑定本地信息时, localaddr 并未写明具体 ipv4 地址,而只是用 “” 代替,是因为程序运行时会自动匹配上本地的已连接的 ipv4 地址,无需自己设置(自己设置也行)
  • 2.并且绑定信息时必须绑定自己电脑的ip以及port,其他的不行
好的,我可以回答这个问题。以下是使用C语言实现UDP绑定IPv6地址和23232端口,并接收该端口数据的示例代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include <netdb.h> #include <arpa/inet.h> #include <netinet/in.h> #define PORT "23232" // 端口号 #define BUF_SIZE 1024 // 缓冲区大小 int main() { int sockfd; // socket描述符 struct addrinfo hints, *res, *p; // addrinfo结构体 struct sockaddr_storage client_addr; // 客户端地址结构体 socklen_t client_addr_len; char buf[BUF_SIZE]; int num_bytes; memset(&hints, 0, sizeof hints); hints.ai_family = AF_INET6; // 使用IPv6 hints.ai_socktype = SOCK_DGRAM; // UDP协议 hints.ai_flags = AI_PASSIVE; // 使用本机IP地址 // 获取地址信息 if (getaddrinfo(NULL, PORT, &hints, &res) != 0) { perror("getaddrinfo"); return 1; } // 遍历地址信息链表,直到绑定成功或遍历完所有地址信息 for (p = res; p != NULL; p = p->ai_next) { sockfd = socket(p->ai_family, p->ai_socktype, p->ai_protocol); if (sockfd == -1) { perror("socket"); continue; } if (bind(sockfd, p->ai_addr, p->ai_addrlen) == -1) { close(sockfd); perror("bind"); continue; } break; } // 释放地址信息链表 freeaddrinfo(res); if (p == NULL) { fprintf(stderr, "failed to bind socket\n"); return 2; } printf("listening on port %s...\n", PORT); // 接收数据并打印 while (1) { client_addr_len = sizeof client_addr; num_bytes = recvfrom(sockfd, buf, BUF_SIZE - 1, 0, (struct sockaddr *)&client_addr, &client_addr_len); if (num_bytes == -1) { perror("recvfrom"); continue; } // 将接收到的数据转换为字符串 buf[num_bytes] = '\0'; // 打印客户端地址和接收到的数据 char client_addr_str[INET6_ADDRSTRLEN]; inet_ntop(client_addr.ss_family, &((struct sockaddr_in6 *)&client_addr)->sin6_addr, client_addr_str, INET6_ADDRSTRLEN); printf("received %d bytes from %s: %s\n", num_bytes, client_addr_str, buf); } // 关闭socket close(sockfd); return 0; } ``` 此代码会绑定本机IPv6地址和23232端口,并接收该端口的数据。你可以将代码保存为文件,使用以下命令编译并运行: ``` $ gcc udp_server.c -o udp_server $ ./udp_server ``` 当接收到数据时,程序会打印客户端地址和接收到的数据。你可以使用其他设备发送UDP数据包到本机的IPv6地址和23232端口,然后在终端上观察程序的输出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值