. UDP Socket编程

先讲一讲UDP编程,因为比TCP要简单多了。首先,我们需要明白UDP是用户数据报协议,英文名为User Datagram Protocol,它是面向无连接的。

注意:Socket通信一定有要服务端和客户端。
1.1 UDP Socket客户端 客户端的工作流程:首先调用socket函数创建一个Socket,然后指定服务端的IP地址和端口号,就可以调用sendto将字符串传送给服务器端,并可以调用recvfrom接收服务器端返回的字符串,最后关闭该socket。 笔者这里分成了四步: 第一步:创建socket并配置socket,如服务端ip地址和端口号
第二步:调用sendto发送消息到服务器端
第三步:调用recvfrom接收来自服务器端的消息
第四步:调用close关闭socket 1.1. 客户端的代码实现: - (void)udpClient {
int clientSocketId;
ssize_t len;
socklen_t addrlen;
struct sockaddr_in client_sockaddr;
char buffer[] = "Hello, server, how are you?"; // 第一步:创建Socket
clientSocketId = socket(AF_INET, SOCK_DGRAM, );
if(clientSocketId < ) {
NSLog(@"creat client socket fail\n");
return;
} addrlen = sizeof(struct sockaddr_in);
bzero(&client_sockaddr, addrlen);
client_sockaddr.sin_family = AF_INET;
client_sockaddr.sin_addr.s_addr = inet_addr("192.168.1.107");
client_sockaddr.sin_port = htons(); int count = ;
do {
bzero(buffer, sizeof(buffer));
sprintf(buffer, "%s", "Hello, server, how are you?"); // 第二步:发送消息到服务端
// 注意:UDP是面向无连接的,因此不用调用connect()
// 将字符串传送给server端
len = sendto(clientSocketId, buffer, sizeof(buffer), , (struct sockaddr *)&client_sockaddr, addrlen); if (len > ) {
NSLog(@"发送成功");
} else {
NSLog(@"发送失败");
} // 第三步:接收来自服务端返回的消息
// 接收server端返回的字符串
bzero(buffer, sizeof(buffer));
len = recvfrom(clientSocketId, buffer, sizeof(buffer), , (struct sockaddr *)&client_sockaddr, &addrlen);
NSLog(@"receive message from server: %s", buffer); count--;
} while (count >= ); // 第四步:关闭socket
// 由于是面向无连接的,消息发出处就可以了,不用管它收不收得到,发完就可以关闭了
close(clientSocketId);
} 1.1. 客户端的打印日志 -- ::36.095 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.286 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.286 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.291 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.291 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.296 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.296 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.316 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.317 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.324 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.324 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.328 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.329 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.339 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.339 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.355 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.356 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.366 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.366 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.372 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you?
-- ::36.373 iOS-Socket-C-Version-Client[:] 发送成功
-- ::36.392 iOS-Socket-C-Version-Client[:] receive message from server: Hello, server, how are you? 1.2 UDP Socket服务器端 服务器端的工作流程:首先调用socket函数创建一个套接字,然后调用bind函数将其与本机地址以及一个本地端口号绑定,接收到一个客户端时,服务器显示该客户端的IP地址,并将字串返回给客户端。 笔者这里分成了五步: 第一步:创建socket并配置socket
第二步:调用bind绑定服务器本机ip及端口号
第三步:调用recvfrom接收来自客户端的消息
第四步:调用sendto将接收到服务器端的信息返回给客户端
第四步:调用close关闭socket 1.2. 服务器端代码实现 - (void)udpServer {
int serverSockerId = -;
ssize_t len = -;
socklen_t addrlen;
char buff[];
struct sockaddr_in ser_addr; // 第一步:创建socket
// 注意,第二个参数是SOCK_DGRAM,因为udp是数据报格式的
serverSockerId = socket(AF_INET, SOCK_DGRAM, ); if(serverSockerId < ) {
NSLog(@"Create server socket fail");
return;
} addrlen = sizeof(struct sockaddr_in);
bzero(&ser_addr, addrlen); ser_addr.sin_family = AF_INET;
ser_addr.sin_addr.s_addr = htonl(INADDR_ANY);
ser_addr.sin_port = htons(); // 第二步:绑定端口号
if(bind(serverSockerId, (struct sockaddr *)&ser_addr, addrlen) < ) {
NSLog(@"server connect socket fail");
return;
} do {
bzero(buff, sizeof(buff)); // 第三步:接收客户端的消息
len = recvfrom(serverSockerId, buff, sizeof(buff), , (struct sockaddr *)&ser_addr, &addrlen);
// 显示client端的网络地址
NSLog(@"receive from %s\n", inet_ntoa(ser_addr.sin_addr));
// 显示客户端发来的字符串
NSLog(@"recevce:%s", buff); // 第四步:将接收到的客户端发来的消息,发回客户端
// 将字串返回给client端
sendto(serverSockerId, buff, len, , (struct sockaddr *)&ser_addr, addrlen);
} while (strcmp(buff, "exit") != ); // 第五步:关闭socket
close(serverSockerId);
} 1.2. 服务器端的打印日志 -- ::36.268 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.269 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.372 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.372 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.377 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.377 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.382 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.382 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.405 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.405 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.409 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.410 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.414 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.415 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.425 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.426 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.441 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.441 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.452 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.452 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you?
-- ::36.472 iOS-Socket-C-Version-Server[:] receive from 192.168.1.100
-- ::36.473 iOS-Socket-C-Version-Server[:] recevce:Hello, server, how are you? 我们这里打印出了客户端发来的消息,由于上面实现的代码中,只发10次,所以这里只有10条。 参考:https://github.com/CoderJackyHuang/iOS-Socket-C-Version 注意:这里面有两个工程,一个是客户端,一个是服务器端。运行时,先运行服务器端,然后再选择客户端。另外,客户端所指定的服务器端的ip地址一定要修改成您本机对应的ip,不然使用笔者这里的ip就会失败。

iOS Socket编程-C语言版(UDP)的更多相关文章

  1. iOS Socket编程-C语言版(TCP)

    . TCP Socket编程 TCP是面向连接的,安全可靠的传输层协议.TCP的程序基本框架设计图: TCP的程序基本框架设计图.jpg 注意:Socket通信一定有要服务端和客户端. 1.1 TCP ...

  2. 计算机网络(十三),Socket编程实现TCP和UDP

    十三.Socket编程实现TCP和UDP 1.TCP (1)TCPServer.java类 package com.interview.javabasic.socket; import com.int ...

  3. 教孩子学编程 python语言版PDF高清完整版免费下载|百度云盘|Python入门

    百度云盘:教孩子学编程 python语言版PDF高清完整版免费下载 提取码:mnma 内容简介 本书属于no starch的经典系列之一,英文版在美国受到读者欢迎.本书全彩印刷,寓教于乐,易于学习:读 ...

  4. python socket 编程(TCP与UDP)

    实验环境:python2 一.TCP编程 1.建立TCP服务器 ①创建TCPServer.py文件 ②编写服务器代码 1)创建socket对象,调用socket构造函数 2)绑定ip端口(IP号和端口 ...

  5. Socket编程(C语言实现):socket()函数英文翻译

    最近开始研究使用Socket API来网络编程,想着把自己的感想.感悟写下来.我发现在编程之外还有不少概念性的东西要学习.我觉得应该有以下几点吧: 1.得了解下计算机网络的基本概念,如OSI的7层模型 ...

  6. win32 socket 编程(六)——UDP

    基于 UDP 无连接的 socket 编程 一.服务器端操作流程 1.1加载套接字库(WSAStartup) 1.2 创建套接字  (socket) 1.3将创建的套接字绑定到一个本地地址和端口上   ...

  7. iOS Socket编程(一)基本概念

    1.Socket的解释 Socket翻译过来中文称为套接字, 这里我找到了一段比较官方的解释Socket是什么东西: Socket是通信的基石,是支持TCP/IP协议的网络通信的基本操作单元,包含进行 ...

  8. iOS socket编程 第三方库 AsyncSocket(GCDAsyncSocket)

    Socket描述了一个IP.端口对.它简化了程序员的操作,知道对方的IP以及PORT就可以给对方发送消息,再由服务器端来处理发送的这些消息.所以,Socket一定包含了通信的双发,即客户端(Clien ...

  9. python网络编程socket编程(TCP、UDP客户端服务器)

    摘录 python核心编程 使用socket()模块函数创建套接字——通信端点 >>> from socket import * >>> tcpSock = soc ...

随机推荐

  1. (转)使用XCode6打开项目以后再用XCode5出现的问题fatal error: malformed or corrupted AST file: 'Unable to load module

    使用不同版本的XCode出现的问题: fatal error: malformed or corrupted AST file: 'Unable to load module "/Users ...

  2. 021-centos6.5上二进制安装mysql5.7.22

    思路: 下载上传mysql的二进制安装包. 准备好mysql的用户.安装目录basedir.数据目录datadir.配置文件/etc/my.cnf. 初始化出数据库. 配置启动服务. 开机启动. 配置 ...

  3. Spring Security中异常上抛机制及对于转型处理的一些感悟

    在使用Spring Security的过程中,我们会发现框架内部按照错误及问题出现的场景,划分出了许许多多的异常,但是在业务调用时一般都会向外抛一个统一的异常出来,为什么要这样做呢,以及对于抛出来的异 ...

  4. JSON草稿

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  5. Linux基础命令---bzmore

    bzmore 将bzip压缩过的文件解压到标准输出,同时也可以将普通文件显示到标准输出.该指令可以实现分屏显示,并且不会删除压缩包.bzmore是一个过滤器,它允许在软拷贝终端上一次检查压缩或纯文本文 ...

  6. php打印负载函数、Linux awk打印负载

    php的sys_getloadavg sys_getloadavt()可以获得系统负载情况.该函数返回一个包含三个元素的数组,每个元素分别代表系统再过去的1.5和15分钟内的平均负载. 与其让服务器因 ...

  7. ELK之elasticsearch6.5集群

    前面介绍并初试了es6.5系列的单节点的操作,现在搭建es6.5系列的集群: 环境:三节点:master-172.16.23.128.node1-172.16.23.129.node2-172.16. ...

  8. 20145310 《网络对抗》 MSF基础应用

    实验要求 掌握metasploit的基本应用方式,掌握常用的三种攻击方式的思路. 一个主动攻击,如ms08_067; 一个针对浏览器的攻击,如ms11_050: 一个针对客户端的攻击,如Adobe 成 ...

  9. 20145334赵文豪《网络对抗》-逆向及Bof基础实践

    本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数,foo函数会简单回显任何用户输入的字符串. 该程序同时包含另一个代码片段,getShell,会返 ...

  10. python函数总结

    1.函数是一种子程序.程序员使用函数来减少代码重复,并用于组织或模块化程序.一旦定义了函数,它可以从程序中的许多不同位置被多次调用.参数允许函数具有可更改的部分.函数定义中出现的参数称之为形参,函数调 ...