Linux下搭建一个简单的UDP通信
2016-07-26 23:42
501 查看
基础知识
UDP和TCP的区别:
1、TCP是面向连接的,而UDP是非面向连接的,因此TCP更可靠
2、UDP的server端的socket不需要监听
3、二者的server端都需要绑定
代码实现:
Server端:
Client端:
目前这段代码 仅仅是 一端能不断地向另一端发送数据,另一端会不断接收。
要想像即时通讯软件那样实现聊天的功能,还在研究ing
UDP和TCP的区别:
1、TCP是面向连接的,而UDP是非面向连接的,因此TCP更可靠
2、UDP的server端的socket不需要监听
3、二者的server端都需要绑定
代码实现:
Server端:
/************************************************************************* > File Name: server.c > Author: HonestFox > Mail: zhweizhi@foxmail.com > Created Time: Sun 24 Jul 2016 09:23:45 PM CST ************************************************************************/ #include<stdio.h> #include<sys/types.h> #include<sys/socket.h> #include<arpa/inet.h> #include<string.h> #include<unistd.h> #include<netinet/in.h> #include<stdlib.h> static void usage(const char *proc) { printf("usage : %s IP : %s\n", proc, proc); } int main(int argc, char *argv[]) { if( argc != 3) { usage(argv[0]); return 1; } int sock = socket(AF_INET, SOCK_DGRAM, 0); if( sock < 0) { perror("socket"); exit(1); } //1.Create a Socket struct sockaddr_in local; local.sin_family = AF_INET; local.sin_port = htons(atoi(argv[2]) ); local.sin_addr.s_addr = inet_addr(argv[1]); //2.Bind if(bind(sock, (struct sockaddr*)&local, sizeof(local) ) < 0) { perror("bind error"); return 2; } //3.Receive & Send int done = 0; struct sockaddr_in peer; socklen_t len = sizeof(peer); char buf[1024]; while(!done) { memset(buf, '\0', sizeof(buf)); recvfrom(sock, buf, sizeof(buf), 0, (struct sockaddr*)&peer, &len); printf("client: %s\n", buf); } return 0; }
Client端:
/************************************************************************* > File Name: client.c > Author: HonestFox > Mail: zhweizhi@foxmail.com > Created Time: Sun 24 Jul 2016 09:23:41 PM CST ************************************************************************/ #include<stdio.h> #include<sys/types.h> #include<sys/socket.h> #include<arpa/inet.h> #include<string.h> #include<netinet/in.h> #include<unistd.h> #include<stdlib.h> static void usage(const char *proc) { printf("usage : %s IP : %s\n", proc, proc); } int main(int argc, char *argv[]) { if( argc != 3) { usage(argv[0]); return 1; } int sock = socket(AF_INET, SOCK_DGRAM, 0); if( sock < 0) { perror("socket"); exit(1); } //1.Create a Socket struct sockaddr_in remote; remote.sin_family = AF_INET; remote.sin_port = htons(atoi(argv[2]) ); remote.sin_addr.s_addr = inet_addr(argv[1]); //2.No Need to Bind //3 Send & Receive int done = 0; struct sockaddr_in peer; socklen_t len = sizeof(peer); char buf[1024]; while(!done) { memset(buf, '\0', sizeof(buf)); printf("plz enter: "); fflush(stdout); ssize_t _s = read(0, buf, sizeof(buf) - 1); if(_s > 0) { buf[_s - 1] = '\0'; sendto(sock, buf, sizeof(buf), 0, (struct sockaddr*)&remote, sizeof(remote)); memset(buf, '\0', sizeof(buf)); } } return 0; }
目前这段代码 仅仅是 一端能不断地向另一端发送数据,另一端会不断接收。
要想像即时通讯软件那样实现聊天的功能,还在研究ing
相关文章推荐
- Seafile Server本地权限提升漏洞(CVE-2014-5443)
- 从USB安装Ubuntu Server 10.04.3 图文详解
- 使用zabbix监控Nginx活动状态--Part1
- 高效访问Internet-启用ISA Server的缓存
- windows server域用户提升到本地更高权限组中的方法
- 完美解决SQL Server 安装问题:以前的某个程序安装已在安装计算机上创建挂起的文件操作
- IIS 错误 Server Application Error 详细解决方法
- 在WINXP系统上安装SQL Server企业版的方法
- SQL Server 存储过程的分页
- 非常不错的脚本入侵基础知识总结第1/2页
- AS3 Flex基础知识100条
- Ruby基础知识之方法、代码段
- Ruby中require、load、include、extend的区别介绍
- SQL Server复制需要有实际的服务器名称才能连接到服务器
- SQL Server 2000向SQL Server 2008 R2推送数据图文教程
- SQL server 表操作介绍
- SQL Server 2000 注入防护大全(二)
- SQL Server 2000 注入防护大全(一)
- 怎样把Windows server 2003转换成工作站系统
- Windows Server 2007四月CTP发布 下载