数据报套接字服务端和客户端

这里练习用数据报套接字来通讯

listener.c

// 数据报套接字服务器(listener.c):在指定端口监听,收到数据报后关闭连接

#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/wait.h>
#include <netinet/in.h>

#define MYPORT 5000
#define MAXBUFLEN 100

int main(int argc, char *argv[])
{
	int sock_fd;
	struct sockaddr_in my_addr;
	struct sockaddr_in their_addr;
	int addr_len, numbytes;
	char buf[MAXBUFLEN];

	if((sock_fd = socket(AF_INET, SOCK_DGRAM, 0)) == -1)
	{
		perror("socket");
		return 1;
	}
	my_addr.sin_family = AF_INET;
	my_addr.sin_port = htons(MYPORT);
	my_addr.sin_addr.s_addr = INADDR_ANY;	// 自动设置为自己的IP
	bzero(&(my_addr.sin_zero), 8);			// 将结构的其余空间清零

	if(bind(sock_fd, (struct sockaddr*)&my_addr, sizeof(struct sockaddr)) == -1)
	{
		perror("bind");
		return 1;
	}
	addr_len = sizeof(struct sockaddr);
	if((numbytes = recvfrom(sock_fd, buf, MAXBUFLEN, 0, (struct sockaddr*)&their_addr, &addr_len)) == -1)
	{
		perror("recvfrom");
		return 1;
	}
	close(sock_fd);
	printf("got packet from %s\n", inet_ntoa(their_addr.sin_addr));
	printf("packet is %d bytes long\n", numbytes);
	buf[numbytes] = 0;
	printf("packet contains [%s]\n", buf);

	return 0;
}


talker.c

 

// 数据报套接字客户端(talker.c):向指定端口发送数据后关闭连接

#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <netdb.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>

#define MYPORT 5000

int main(int argc, char *argv[])
{
	int sock_fd, numbytes;
	struct sockaddr_in their_addr;
	struct hostent *he;

	if(argc < 3)
	{
		fprintf(stderr, "Usage: %s <hostname> <message>\n", argv[0]);
		return 1;
	}
	if((he = gethostbyname(argv[1])) == NULL)
	{
		herror("gethostbyname");
		return 1;
	}
	if((sock_fd = socket(AF_INET, SOCK_DGRAM, 0)) == -1)
	{
		perror("socket");
		return 1;
	}

	their_addr.sin_family = AF_INET;
	their_addr.sin_port = htons(MYPORT);
	their_addr.sin_addr = *((struct in_addr*)he->h_addr);
	bzero(&(their_addr.sin_zero), 8);

	if((numbytes = sendto(sock_fd, argv[2], strlen(argv[2]), 0, (struct sockaddr*)&their_addr, sizeof(struct sockaddr))) == -1)
	{
		perror("sendto");
		return 1;
	}
	close(sock_fd);
	printf("sent %d bytes to %s\n", numbytes, inet_ntoa(their_addr.sin_addr));

	return 0;
}


 

UDP(User Datagram Protocol)是一种无连接的网络传输协议,它允许数据包在没有事先建立连接的情况下发送出去。在使用UDP套接字创建服务端时,通常包含以下基本步骤: 1. 创建套接字Socket):首先,需要使用特定的协议(在这里是UDP)创建一个套接字。在大多数编程语言中,可以通过调用库函数来完成这一操作。 2. 绑定套接字(Binding):创建套接字后,需要将其绑定到一个端口上。这样,客户端才能知道往哪个地址发送数据包。绑定通常需要指定一个地址和端口号,如果指定的端口已被占用,则绑定会失败。 3. 接收数据(Receiving):服务端创建并绑定套接字后,就可以开始监听来自客户端数据了。通常使用阻塞模式来等待数据包的到达,接收到数据包后,可以从数据包中提取出客户端的地址和发送的数据。 4. 发送数据(Sending):如果需要,服务端也可以向客户端发送数据。发送数据时,需要指定客户端的地址,因为UDP不保持连接状态,所以每次发送都需要指定目标地址。 5. 关闭套接字(Closing):一旦完成通信任务,服务端应该关闭套接字以释放资源。 这些步骤的具体实现会依赖于使用的编程语言和网络库。例如,在Python中,可以使用`socket`模块来创建UDP套接字服务端: ```python import socket # 创建UDP套接字 server_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) # 绑定套接字到指定的IP地址和端口 server_socket.bind(('localhost', 12345)) print("UDP server up and listening") try: while True: # 接收数据 data, client_address = server_socket.recvfrom(1024) print(f"Received message: {data} from {client_address}") # 可选:向客户端发送应答消息 server_socket.sendto(b'ACK', client_address) finally: # 关闭套接字 server_socket.close() ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值