//

//  该类管理所有的UDP发送

#import <Foundation/Foundation.h>

#import "AsyncUdpSocket.h"

@protocolUDPManagerDelegate;

#define fromHostKey @"fromHost"

#define dataKey @"data"

#define socketTypeKey @"socketType"

#define errorTypeKey @"error"

typedefenum{

NewDevice=0x01,//设备发现

AddDevice=0x02,//添加设备

ControlDevice=0x11,//控制设备

//    TimeQuery=0xFD,//查询定时状态

}SocketNotificationType;

@interface UDPManager : NSObject

{

AsyncUdpSocket *udpSocket;

}

+(UDPManager *)instance;

@property(nonatomic,strong) id<UDPManagerDelegate>myDelegate;

//发送UDP信息 isBroadcast为发送的消息是否为广播类型

-(void)sendToUDPServer:(NSData*) msg address:(NSString*)address port:(int)port isBroadcast:(BOOL)isBoradcast;

//关闭Socket

-(void)closeSocket;

@end

@protocol UDPManagerDelegate <NSObject>

//成功接收消息

-(void)UDPManager:(UDPManager *)udpManager didReceiveData:(NSData *)data fromHost:(NSString *)host socketDataType:(SocketNotificationType)type;

//UDP发送或接收失败

-(void)UDPManagerReceive:(UDPManager *)udpManager error:(NSError *)error;

@end

//

//  UDPManager.m

//  SmartHomeWIFI

//

//  Created by 深圳市 秀软科技有限公司 on 14-2-12.

//  Copyright (c) 2014年 huhuaxiang. All rights reserved.

//

//wifi获取网路数据

#import "UDPManager.h"

#import "ByteUnit.h"

#define timerOut 5

static UDPManager *udpManager;

@implementation UDPManager

@synthesize myDelegate;

+(UDPManager *)instance

{

if(!udpManager)

udpManager=[[UDPManageralloc]init];

returnudpManager;

}

-(id)init

{

if(self=[superinit])

{

udpSocket=[[AsyncUdpSocketalloc]initWithDelegate:self];

[udpSocket bindToPort:36666 error:nil];

}

returnself;

}

-(void)dealloc

{

NSLog(@"UDPManager dealloc");

}

-(void)closeSocket

{

[udpSocketclose];

udpSocket=nil;

udpManager=nil;

}

-(void)sendToUDPServer:(NSData*) msg address:(NSString*)address port:(int)port isBroadcast:(BOOL)isBoradcast{

NSLog(@"address:%@,port:%d,msg:%@",address,port,msg);

//receiveWithTimeout is necessary or you won't receive anything

//    [udpSocket receiveWithTimeout:10 tag:0]; //设置超时10秒

//命令标示

unsignedlong mlflag = [ByteUnitsubDataLength:msg startCount:0lenghtCount:1];

SocketNotificationType type=[selfgetTagType:mlflag];

[udpSocketreceiveWithTimeout:timerOuttag:0]; //设置超时10秒

[udpSocketenableBroadcast:isBoradcast error:nil]; //如果你发送广播,这里必须先enableBroadcast

[udpSocket sendData:msg toHost:address port:port withTimeout:timerOut tag:type]; //发送udp

}

- (BOOL)onUdpSocket:(AsyncUdpSocket *)sock didReceiveData:(NSData *)data withTag:(long)tag fromHost:(NSString *)host port:(UInt16)port

{

//    NSMutableData *dataMutable=[[NSMutableData alloc]initWithData:data];

//命令标示

unsignedlong mlflag = [ByteUnitsubDataLength:data startCount:0lenghtCount:1];

SocketNotificationType type=[selfgetTagType:mlflag];

NSMutableDictionary *dic=[[NSMutableDictionaryalloc]init];

[dic setObject:data forKey:dataKey];

[dic setObject:host forKey:fromHostKey];

[dic setObject:[NSNumbernumberWithInt:type] forKey:socketTypeKey];

[[NSNotificationCenterdefaultCenter] postNotificationName:updateSocketNotificationTypeobject:dic];

//    if([myDelegate respondsToSelector:@selector(UDPManager:didReceiveData:fromHost:socketDataType:)])

//        [myDelegate UDPManager:self didReceiveData:data fromHost:host socketDataType:type];

//    [udpSocket receiveWithTimeout:timerOut tag:tag];

returnYES;

}

-(SocketNotificationType)getTagType:(int)mlflag

{

SocketNotificationType type;

switch (mlflag) {//回复类型

case 0x01://心跳

type=NewDevice;

break;

case 0x02://添加设备

type=AddDevice;

break;

case 0x11://控制设备

type=ControlDevice;

break;

//        case 0xFD://查询定时

//            type=TimeQuery;

//            break;

}

return type;

}

- (void)onUdpSocket:(AsyncUdpSocket *)sock didNotSendDataWithTag:(long)tag dueToError:(NSError *)error

{

NSMutableDictionary *dic=[[NSMutableDictionaryalloc]init];

[dic setObject:[NSNumbernumberWithInt:tag] forKey:errorTypeKey];

[[NSNotificationCenterdefaultCenter] postNotificationName:updateSocketNotificationTypeobject:dic];

//    if([myDelegate respondsToSelector:@selector(UDPManagerReceive:error:)])

//        [myDelegate UDPManagerReceive:self error:error];

}

- (void)onUdpSocket:(AsyncUdpSocket *)sock didNotReceiveDataWithTag:(long)tag dueToError:(NSError *)error

{

NSMutableDictionary *dic=[[NSMutableDictionaryalloc]init];

[dic setObject:[NSNumbernumberWithInt:tag] forKey:errorTypeKey];

[[NSNotificationCenterdefaultCenter] postNotificationName:updateSocketNotificationTypeobject:dic];

//    if([myDelegate respondsToSelector:@selector(UDPManagerReceive:error:)])

//        [myDelegate UDPManagerReceive:self error:error];

}

@end

UDP的使用的更多相关文章

  1. Node.js:dgram模块实现UDP通信

    1.什么是UDP? 这里简单介绍下,UDP,即用户数据报协议,一种面向无连接的传输层协议,提供不可靠的消息传送服务.UDP协议使用端口号为不同的应用保留其各自的数据传输通道,这一点非常重要.与TCP相 ...

  2. 高性能 TCP/UDP/HTTP 通信框架 HP-Socket v4.1.1

    HP-Socket 是一套通用的高性能 TCP/UDP/HTTP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP/HTTP 通信系统,提供 C/ ...

  3. TODO:Golang语言TCP/UDP协议重用地址端口

    TODO:Golang语言TCP/UDP协议重用地址端口 这是一个简单的包来解决重用地址的问题. go net包(据我所知)不允许设置套接字选项. 这在尝试进行TCP NAT时尤其成问题,其需要在同一 ...

  4. 利用Docker技术实现UDP广播效果(网络编程python版)

    docker的安装见官方文档 我使用的系统为Ubuntu16.04 Ubuntu系统安装docker文档地址:https://docs.docker.com/engine/installation/l ...

  5. 【Win 10 应用开发】UDP广播

    我们知道,对于UDP协议的通信,除了可以用来聊天外,可以发送广播数据.只要向广播地址的某个端口发送数据就可以进行广播,子网中只要监听该端口的socket就能收到广播消息. 最简单的方法就是向255.2 ...

  6. 高性能 TCP/UDP/HTTP 通信框架 HP-Socket v4.1.2

    HP-Socket 是一套通用的高性能 TCP/UDP/HTTP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP/HTTP 通信系统,提供 C/ ...

  7. 高性能 TCP/UDP/HTTP 通信框架 HP-Socket v4.0.1

    HP-Socket 是一套通用的高性能 TCP/UDP/HTTP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP/HTTP 通信系统,提供 C/ ...

  8. 高性能 TCP & UDP 通信框架 HP-Socket v3.5.3

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  9. 高性能 TCP & UDP 通信框架 HP-Socket v3.5.2

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  10. 高性能 TCP & UDP 通信框架 HP-Socket v3.5.1

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

随机推荐

  1. 数据加密标准——DES

    DES算法和DESede算法统称DES系列算法.DES算法是对称加密算法领域中的典型算法,为后续对称加密算法的发展奠定了坚实的基础.但是DES算法密钥偏短,仅有56位,迭代次数偏少,受到诸如查分密码分 ...

  2. 【资讯】天啦鲁,这十余款创客设计居然由FPGA搞定 [转]

    按理说‘高大上’的FPGA,多出现在航天航空(如火星探测器).通信(如基站.数据中心).测试测量等高端应用场景.但麦迪却也发现,近期,在很多创客的作品内部都有FPGA的影子.这或许也从侧面看出,打从总 ...

  3. javascript类继承的一些实验

    其实一开始编js没怎么用过对象,一般都用func,func,func···但是用多了,感觉代码一点都不美观,还要这里包一个函数,那里包一个函数,或者一直都是函数调用,不好看,而且一些重用的都要重写的话 ...

  4. μC/OS-Ⅲ系统的源代码文件组织结构

  5. Bootstrap <基础三十一>插件概览

    在前面布局组件中所讨论到的组件仅仅是个开始.Bootstrap 自带 12 种 jQuery 插件,扩展了功能,可以给站点添加更多的互动.即使不是一名高级的 JavaScript 开发人员,也可以着手 ...

  6. 《Pro Express.js》学习笔记——app.params中间件

    app.param中间件用于对URL中的参数进行获取.加工.输出,提供公有逻辑,以达到代码重构的目的. 以下示例采取三个步骤对代码进行重构,app.param中间件的作用非常明显: 不使用中间件 使用 ...

  7. mysql数据类型和列属性

    列属性: 定义一个字段时对该字段设置的额外的信息或约束 1.  关联操作:reference 2.  字段默认值:default value 3.  主索引和唯一索引:primary key 和uni ...

  8. React之事件绑定、列表中key的使用

    在学习React的Hadding Events这一章节,发现事件回调函数的几种写法,看似区别不大,但实际差异还是蛮大的. class Toggle extends React.Component{ c ...

  9. Groovy解析xml并且注入Project,TestSuite,TestCase级别的custom properties

    import com.eviware.soapui.support.GroovyUtils import groovy.util.XmlParser def groovyUtils = new Gro ...

  10. Devexpress DateEdit控件的值不反馈到数据源的处理方式。

    如果在GridControl中要把编辑的值反馈到数据源,可以用Gridview1.PostEdit()方法. 可是在datalayout中使用就会遇到一些问题:比如说DateEdit控件,在保存数据的 ...