1.UDP编程的服务器端一般步骤是:
2.UDP编程的客户端一般步骤是:
1、创建一个socket,用函数socket(); 2、设置socket属性,用函数setsockopt();* 可选 3、绑定IP地址、端口等信息到socket上,用函数bind(); 4、循环接收数据,用函数recvfrom(); 5、关闭网络连接; |
2.UDP编程的客户端一般步骤是:
1、创建一个socket,用函数socket(); 2、设置socket属性,用函数setsockopt();* 可选 3、绑定IP地址、端口等信息到socket上,用函数bind();* 可选 4、设置对方的IP地址和端口等属性; 5、发送数据,用函数sendto(); 6、关闭网络连接; |
3.recvfrom和sendto函数
#inlcude <sys/socket.h>
ssize_t recvfrom(int sockfd,void *buff,size_t nbytes,int flags,struct sockaddr *from,socklen_t *addrlen);
ssize_t sendto(int sockfd,const void *buff,size_t nbytes,int flags,const struct sockaddr *to,socklen_t addrlen);
#include <stdio.h>
#include <string.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <sys/socket.h>
#include <errno.h>
#include <stdlib.h>
#include <arpa/inet.h>
int main(int argc, char **argv)
{
struct sockaddr_in s_addr;
int sock;
int addr_len;
int len;
char buff[128];
/* 创建 socket , 关键在于这个 SOCK_DGRAM */
if ((sock = socket(AF_INET, SOCK_DGRAM, 0)) == -1) {
perror("socket");
exit(errno);
} else
printf("create socket.\n\r");
/* 设置对方地址和端口信息 */
s_addr.sin_family = AF_INET;
if (argv[2])
s_addr.sin_port = htons(atoi(argv[2]));
else
s_addr.sin_port = htons(7838);
if (argv[1])
s_addr.sin_addr.s_addr = inet_addr(argv[1]);
else {
printf("消息必须有一个接收者!\n");
exit(0);
}
/* 发送UDP消息 */
addr_len = sizeof(s_addr);
strcpy(buff, "hello i'm here");
len = sendto(sock, buff, strlen(buff), 0,
(struct sockaddr *) &s_addr, addr_len);
if (len < 0) {
printf("\n\rsend error.\n\r");
return 3;
}
printf("send success.\n\r");
return 0;
}
#include <stdio.h>
#include <string.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <sys/socket.h>
#include <errno.h>
#include <stdlib.h>
#include <arpa/inet.h>
/********************************************************************
函数名:服务器初始化函数
参考:APUE
功能:socket,bind,listen动作的集合
返回值:成功返回套接字描述符,失败返回-1
*******************************************************************/
int initserver(int type,const struct sockaddr *addr,socklen_t alen,int qlen)
{
int fd;
int err=0;
if((fd=socket(addr->sa_family,type,0))<0)
return -1;
if(bind(fd,addr,alen)<0)
goto errout;
if(type==SOCK_STREAM || type==SOCK_SEQPACKET) //SOCK_DGRAM不用listen
{
if(listen(fd,qlen)<0)
goto errout;
}
return fd;
errout:
err=errno;
close(fd);
errno=err;
return -1;
}
int main(int argc,char **argv)
{
struct sockaddr_in s_addr;
struct sockaddr_in c_addr;
int sockfd;
socklen_t addr_len;
int len;
char buff[128];
/*设置地址和端口*/
bzero(&s_addr,sizeof(s_addr));
s_addr.sin_family=AF_INET;
if(argv[2]) s_addr.sin_port=htons(atoi(argv[2]));
else s_addr.sin_port=htons(7838);
if(argv[1]) s_addr.sin_addr.s_addr=inet_addr(argv[1]);
else s_addr.sin_addr.s_addr=INADDR_ANY;
if((sockfd=initserver(SOCK_DGRAM,(struct sockaddr *)&s_addr,sizeof(struct sockaddr),0))==-1)
{
perror("init server");
exit(1);
}
/*循环接收数据*/
addr_len=sizeof(c_addr);
while(1)
{
len=recvfrom(sockfd,buff,sizeof(buff)-1,0,(struct sockaddr *)&c_addr,&addr_len);
if(len<0)
{
perror("recvfrom");
exit(errno);
}
buff[len]='\0';
printf("收到来自%s:%d的消息:%s\n\r",inet_ntoa(c_addr.sin_addr),ntohs(c_addr.sin_port),buff);
return 0;
}
}