UDP-双向通信
使用UDP手实现两台主机主机直接的通信,使用两个线程,一个用于接受一个用于发送,两台主机的端口号必须相同
/**************************************************************************
*
* 设计客户端和服务器之间的全双工通信 客户端程序
* author:jindouliu2024@163.com
* date:2025.5.14
* notice:argv[1]:服务器的端口 argv[2]:服务器的IP
* argv[3]:客户端(本地)的端口 argv[4]:客户端(本地)的IP
*
* Copyright (c) 2024-2025 jindouliu2024@163.com All right Reserved
* *************************************************************************/
#include<stdio.h>
#include<string.h>
#include<errno.h>
#include<stdlib.h>
#include<arpa/inet.h>
#include <unistd.h>
#include<netinet/udp.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include <pthread.h>
pthread_t task1_id;
pthread_t task2_id;
int udp_socket;
char *data[4];
struct sockaddr_in server_addr;
struct sockaddr_in client;
//向服务器发送数据
void * task1(void *arg)
{
char buf[128] = "this is task1,client sending";
while(1){
//发送数据
sendto(udp_socket,buf,strlen(buf),0,(struct sockaddr *)&server_addr,sizeof(server_addr));
sleep(10);
}
pthread_exit(NULL);
}
//接收服务器的数据
void *task2(void *arg)
{
char buf[128] = {0};
struct sockaddr_in server;
socklen_t server_size = sizeof(server);
while (1) {
// 准备接收数据
int bytes_received = recvfrom(udp_socket, buf, sizeof(buf), 0, (struct sockaddr *)&server, &server_size);
if (bytes_received > 0) {
printf("data is %s\n", buf);
} else {
fprintf(stderr, "recvfrom error errno:%d,%s", errno, strerror(errno));
}
bzero(buf, sizeof(buf));
}
pthread_exit(NULL);
}
int main(int argc,char *argv[])
{
for(int i=0;i<4;i++){
data[i] = argv[i+1];
}
//创建一个网络套接字
udp_socket = socket(AF_INET,SOCK_DGRAM,0);
if(udp_socket == -1){
fprintf(stderr,"socket error errno:%d,%s",errno,strerror(errno));
return 1;
}
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(atoi(data[0]));
server_addr.sin_addr.s_addr = inet_addr(data[1]);
//绑定客户端的端口和地址
//struct sockaddr_in client;
client.sin_family = AF_INET;
client.sin_port = htons(atoi(data[2]));
client.sin_addr.s_addr = inet_addr(data[3]);
bind(udp_socket,(struct sockaddr *)&client,sizeof(client));
//创建两个线程,一个用于发送一个用于接受
pthread_create(&task1_id,NULL,task1,NULL);
pthread_create(&task2_id,NULL,task2,NULL);
//绑定服务器的端口和地址
pthread_exit(NULL);
return 0;
/**************************************************************************
*
* 设计客户端和服务器之间的全双工通信 服务器程序
* author:jindouliu2024@163.com
* date:2025.5.14
* notice:argv[1]:服务器的端口 argv[2]:服务器的IP
* argv[3]:客户端(本地)的端口 argv[4]:客户端(本地)的IP
*
*
* Copyright (c) 2024-2025 jindouliu2024@163.com All right Reserved
* *************************************************************************/
#include<stdio.h>
#include<string.h>
#include<errno.h>
#include<stdlib.h>
#include<arpa/inet.h>
#include <unistd.h>
#include<netinet/udp.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include <pthread.h>
pthread_t task1_id;
pthread_t task2_id;
int udp_socket;
struct sockaddr_in server_addr;
struct sockaddr_in client;
char *data[4];
//向客户端发送数据
void *task1(void *arg)
{
char buf[128] = "this is task1,server sending";
while (1) {
// 发送数据
int sent = sendto(udp_socket, buf, strlen(buf), 0, (struct sockaddr *)&client, sizeof(client));
if (sent < 0) {
fprintf(stderr, "sendto error errno:%d,%s", errno, strerror(errno));
}
sleep(10);
}
pthread_exit(NULL);
}
//接收服务器的数据
void * task2(void *arg)
{
char buf[128] = {0};
// struct sockaddr_in server;
// socklen_t server_size = sizeof(server);
while(1){
//准备接受数据
recvfrom(udp_socket,buf,sizeof(buf),0,NULL,NULL);
printf("server data is %s\n",buf);
bzero(buf,sizeof(buf));
}
pthread_exit(NULL);
}
int main(int argc,char *argv[])
{
//创建一个网络套接字
udp_socket = socket(AF_INET,SOCK_DGRAM,0);
if(udp_socket == -1){
fprintf(stderr,"socket error errno:%d,%s",errno,strerror(errno));
return 1;
}
//绑定服务器的端口和地址
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(atoi(argv[1]));
server_addr.sin_addr.s_addr = inet_addr(argv[2]);
bind(udp_socket,(struct sockaddr *)&server_addr,sizeof(server_addr));
//绑定客户端的端口和地址
client.sin_family = AF_INET;
client.sin_port = htons(atoi(argv[3]));
client.sin_addr.s_addr = inet_addr(argv[4]);
//创建两个线程,一个用于发送一个用于接受
pthread_create(&task1_id,NULL,task1,NULL);
pthread_create(&task2_id,NULL,task2,NULL);
pthread_exit(NULL);
return 0;
}