sendto(经socket传送数据)
相关函数 | send , sendmsg,recv , recvfrom , socket |
表头文件 | #include < sys/types.h > #include < sys/socket.h > |
定义函数 | int sendto ( int s , const void * msg, int len, unsigned int flags, const struct sockaddr * to , int tolen ) ; |
函数说明 | sendto() 用来将数据由指定的socket传给对方主机。参数s为已建好连线的socket,如果利用UDP协议则不需经过连线操作。参数msg指向欲连线的数据内容,参数flags 一般设0,详细描述请参考send()。参数to用来指定欲传送的网络地址,结构sockaddr请参考bind()。参数tolen为sockaddr的结果长度。 |
返回值 | 成功则返回实际传送出去的字符数,失败返回-1,错误原因存于errno 中。 |
错误代码 | EBADF 参数s非法的socket处理代码。 EFAULT 参数中有一指针指向无法存取的内存空间。 WNOTSOCK canshu s为一文件描述词,非socket。 EINTR 被信号所中断。 EAGAIN 此动作会令进程阻断,但参数s的soket为补课阻断的。 ENOBUFS 系统的缓冲内存不足。 EINVAL 传给系统调用的参数不正确。 |
recvfrom(经socket接收数据) |
相关函数 | recv,recvmsg,send,sendto,socket |
表头文件 | #include<sys/types.h> #include<sys/socket.h> |
定义函数 | int recvfrom(int s,void *buf,int len,unsigned int flags ,struct sockaddr *from ,int *fromlen); |
函数说明 | recv()用来接收远程主机经指定的socket 传来的数据,并把数据存到由参数buf 指向的内存空间,参数len 为可接收数据的最大长度。参数flags 一般设0,其他数值定义请参考recv()。参数from用来指定欲传送的网络地址,结构sockaddr 请参考bind()。参数fromlen为sockaddr的结构长度。 |
返回值 | 成功则返回接收到的字符数,失败则返回-1,错误原因存于errno中。 |
错误代码 | EBADF 参数s非合法的socket处理代码 EFAULT 参数中有一指针指向无法存取的内存空间。 ENOTSOCK 参数s为一文件描述词,非socket。 EINTR 被信号所中断。 EAGAIN 此动作会令进程阻断,但参数s的socket为不可阻断。 ENOBUFS 系统的缓冲内存不足 ENOMEM 核心内存不足 EINVAL 传给系统调用的参数不正确。 |
server.c
- <span style="font-size: 16px;">#include <sys/types.h>
- #include <sys/socket.h>
- #include <netinet/in.h>
- #include <arpa/inet.h>
- #include <unistd.h>
- #include <stdlib.h>
- #include <string.h>
- #include <stdio.h>
- #define PORT 1111 /*使用的port*/
- main(){
- int sockfd,len;
- struct sockaddr_in addr;
- int addr_len = sizeof(struct sockaddr_in);
- char buffer[256];
- /*建立socket*/
- if((sockfd=socket(AF_INET,SOCK_DGRAM,0))<0){
- perror ("socket");
- exit(1);
- }
- /*填写sockaddr_in 结构*/
- bzero ( &addr, sizeof(addr) );
- addr.sin_family=AF_INET;
- addr.sin_port=htons(PORT);
- addr.sin_addr.s_addr=htonl(INADDR_ANY) ;
- if (bind(sockfd, (struct sockaddr *)&addr, sizeof(addr))<0){
- perror("connect");
- exit(1);
- }
- while(1){
- bzero(buffer,sizeof(buffer));
- len = recvfrom(sockfd,buffer,sizeof(buffer), 0 , (struct sockaddr *)&addr ,&addr_len);
- /*显示client端的网络地址*/
- printf("receive from %s\n" , inet_ntoa( addr.sin_addr));
- /*将字串返回给client端*/
- sendto(sockfd,buffer,len,0,(struct sockaddr *)&addr,addr_len);
- }
- }
- </span>
client.c
- <span style="font-size: 16px;">#include <sys/types.h>
- #include <sys/socket.h>
- #include <netinet/in.h>
- #include <arpa/inet.h>
- #include <unistd.h>
- #include <stdlib.h>
- #include <string.h>
- #include <stdio.h>
- #define PORT 1111
- #define SERVER_IP "127.0.0.1"
- main()
- {
- int s,len;
- struct sockaddr_in addr;
- int addr_len =sizeof(struct sockaddr_in);
- char buffer[256];
- /* 建立socket*/
- if((s = socket(AF_INET,SOCK_DGRAM,0))<0){
- perror("socket");
- exit(1);
- }
- /* 填写sockaddr_in*/
- bzero(&addr,sizeof(addr));
- addr.sin_family = AF_INET;
- addr.sin_port = htons(PORT);
- addr.sin_addr.s_addr = inet_addr(SERVER_IP);
- while(1){
- bzero(buffer,sizeof(buffer));
- /* 从标准输入设备取得字符串*/
- len =read(STDIN_FILENO,buffer,sizeof(buffer));
- /* 将字符串传送给server端*/
- sendto(s,buffer,len,0,(struct sockaddr *)&addr,addr_len);
- /* 接收server端返回的字符串*/
- len = recvfrom(s,buffer,sizeof(buffer),0,(struct sockaddr *)&addr,&addr_len);
- printf("receive: %s",buffer);
- }
- }
- </span>
此实例为无连接UDP,也可用connect函数实现已连接UDP.
(笔记以实例为主,详细理论见<<UNIX网络编程>>)