Linux下C语言实现UDP Socket编程

该博文参考了Linux C socket 编程之UDP一文,在这里表示感谢!

发送方:

/* 
 * File:   udp_sender.c
 * Author: Henry
 *
 * Created on 2019年5月29日17:08:13
 *
 * 主要实现:发送20个文本消息,然后再发送一个终止消息
 */
 
#include 
#include 
 
#include 
#include 
#include 
#include 
#include 

int power(int base, int exp);
int str_to_num(const char *s);

int main(int argc, char** argv) {
	if(argc != 3)
	{
		printf("Warning: Incorrect parameters! Correct usage like this:\nudp_sender ipAddress_of_udpServer port\n");
		exit(0);
	}
    int socket_descriptor; //套接口描述字
    int iter=0;
    char buf[80];
    struct sockaddr_in address;//处理网络通信的地址
 
    bzero(&address,sizeof(address));
    address.sin_family=AF_INET;
    //address.sin_addr.s_addr=inet_addr("192.168.2.1");//这里不一样
    address.sin_addr.s_addr=inet_addr(argv[1]);//这里不一样
    address.sin_port=htons(str_to_num(argv[2]));
 
    //创建一个 UDP socket
 
    socket_descriptor=socket(AF_INET,SOCK_DGRAM,0);//IPV4  SOCK_DGRAM 数据报套接字(UDP协议)
 
    for(iter=0;iter<=20;iter++)
    {
         /*
         * sprintf(s, "%8d%8d", 123, 4567); //产生:" 123 4567" 
         * 将格式化后的字符串存放到s当中
         */
        sprintf(buf,"data packet with ID %d\n",iter);
       
        /*int PASCAL FAR sendto( SOCKET s, const char FAR* buf, int len, int flags,const struct sockaddr FAR* to, int tolen);  
         * s:一个标识套接口的描述字。 
         * buf:包含待发送数据的缓冲区。  
         * len:buf缓冲区中数据的长度。 
         * flags:调用方式标志位。  
         * to:(可选)指针,指向目的套接口的地址。 
         * tolen:to所指地址的长度。  
        */
        sendto(socket_descriptor,buf,sizeof(buf),0,(struct sockaddr *)&address,sizeof(address));
    }
 
    sprintf(buf,"stop\n");
    sendto(socket_descriptor,buf,sizeof(buf),0,(struct sockaddr *)&address,sizeof(address));//发送stop 命令
    close(socket_descriptor);
    printf("Messages Sent,terminating\n");
 
    exit(0);
 
    return (EXIT_SUCCESS);
}

int str_to_num(const char* s)
{
	int exp=0, n=0;
	const char *h = s;
	const char *t = NULL;
	for(;*h <'0' || *h >'9'; h++)  // 找到第一位数字
		;
	for(t=h; *t >='0' && *t <='9'; ++t)  // 找到最后一位数字
		;
	t--;
	while(t >= h)
	{
		n += (*t - 48)*power(10, exp);
		t--;
		exp++;
	}
	return n;
}

int power(int base, int exp)
{
	if( 0 == exp )
		return 1;
	return base*power(base, exp-1);
}

接收方:

/* 
 * File:   udp_receiver.c
 * Author: Henry
 *
 * Created on 2019年5月29日17:09:11
 *
 * 主要实现:发送20个文本消息,然后再发送一个终止消息
 */
 
#include 
#include 
 
#include 
#include 
#include 
#include 
#include 

int power(int base, int exp);
int str_to_num(const char *s);
 
int main(int argc, char** argv) {
	if(argc != 2)
	{
		printf("Warning: Incorrect parameters! Correct usage like this:\nudp_receiver port\n");
		exit(0);
	}
 
    int sin_len;
    char message[256];
 
    int socket_descriptor;
    struct sockaddr_in sin;
    printf("Waiting for data from sender \n");
 
    bzero(&sin,sizeof(sin));
    sin.sin_family=AF_INET;
    sin.sin_addr.s_addr=htonl(INADDR_ANY);
    sin.sin_port=htons(str_to_num(argv[1]));
    sin_len=sizeof(sin);
 
    socket_descriptor=socket(AF_INET,SOCK_DGRAM,0);
    bind(socket_descriptor,(struct sockaddr *)&sin,sizeof(sin));
 
    while(1)
    {
        recvfrom(socket_descriptor,message,sizeof(message),0,(struct sockaddr *)&sin,&sin_len);
        printf("Response from server:%s\n",message);
        if(strncmp(message,"stop",4) == 0)     // 接受到的消息为 “stop”
        {
 
            printf("Sender has told me to end the connection.\n");
            break;
        }
    }
 
    close(socket_descriptor);
    exit(0);
 
    return (EXIT_SUCCESS);
}

int str_to_num(const char* s)
{
	int exp=0, n=0;
	const char *h = s;
	const char *t = NULL;
	for(;*h <'0' || *h >'9'; h++)  // 找到第一位数字
		;
	for(t=h; *t >='0' && *t <='9'; ++t)  // 找到最后一位数字
		;
	t--;
	while(t >= h)
	{
		n += (*t - 48)*power(10, exp);
		t--;
		exp++;
	}
    	return n;
}

int power(int base, int exp)
{
	if( 0 == exp )
		return 1;
	return base*power(base, exp-1);
}

你可能感兴趣的:(C,语言)