//

//  该类管理所有的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. Python从零开始(1)新手常问

    如何清除屏幕 如果是在Windows命令行中,输入 import os os.system('cls') 在IDEL中没有找到完美的清除屏幕的方法 网上提到用新建窗口的方法 如何退出Python提示符 ...

  2. ReportingService报表入门

    今天我们来学习一下ReportingService报表的制作. ReportingService是微软提供的一个制作报表的工具,它集成在Microsoft Visual Studio中. 启动Visu ...

  3. .netcore跨平台 之 windows上编译,ubuntu上运行

    1 下载并安装netcore sdk    下载地址 https://github.com/dotnet/cli 选取合适的版本下载安装即可 打开 CMD ,输入dotnet,出现以下信息说明已安装好 ...

  4. xcode意外退出

    完全不明所以的频繁退出 第一种 排除SVN冲突 在团队开发中,SVN冲突是最常见的了,程序异常时查看SVN文件冲突基本上成了本能. 排除SVN冲突 首先,右键主项目文件即xcodeproj文件,显示包 ...

  5. leetcode日记 Product of Array Except Self

    Given an array of n integers where n > 1, nums, return an array output such that output[i] is equ ...

  6. c语言函数指针

    #include <stdio.h> typedef void (*intFunc)(int i); void test1(int age) { printf("test1:%d ...

  7. Android APP使用NDK编译后的ffmpeg库出现undefined reference to 'posix_memalign'错误

    在android程序中使用NDK编译后的ffmpeg库的时候出现了如下错误: jni/libs/libavutil.a(mem.o): in function av_malloc:libavutil/ ...

  8. Javascript DOM编程艺术 语法部分

    1.变量,可以变化的东西我们称为变量,随着年龄的增大,我们的age不断变大 2.Javascript变量声明用var,可以不声明变量类型.尽量声明为一个字符串字面量. 3.弱类型:要求程序员必须明确的 ...

  9. C++11:新式的字符串字面常量(String Literal)

    自C++11起,我们可以定义 raw string 字符串字面常量. Raw string 允许我们定义所见即所得的字符串字面常量,从而可以省下很多用来修饰特殊 字符的符号. Raw string 以 ...

  10. HIS-DELPHI-读取数据库配置

    产品思维: 1.做成可配置的 2.模块化 医生会有自己熟悉的药品,数据里面药品太多,让医生选择不放便 所以可以让医生自己维护自己的药品模板数据 比如医生开了处方后,可以保存当前的处方到某个模板中,那么 ...