Google Protocol Buffer( 简称 Protobuf) 是 Google 公司内部的混合语言数据标准,目前已经正在使用的有超过 48,162 种报文格式定义和超过 12,183 个 .proto 文件。他们用于 RPC 系统和持续数据存储系统。
Protocol Buffers 是一种轻便高效的结构化数据存储格式,可以用于结构化数据串行化,或者说序列化。它很适合做数据存储或 RPC 数据交换格式。可用于通讯协议、数据存储等领域的语言无关、平台无关、可扩展的序列化结构数据格式。目前提供了 C++、Java、Python 三种语言的 API。
由于我们公司的服务器的数据传输协议是基于谷歌Protobuf协议, 现在由于有朋友也在使用我们的这一套协议,关于其中的使用,特封装了socket的单例类,结合Protobuf的使用做如下总结;
本Demo中封装了从服务器连接到数据解析,数据的字节序,使用心跳包保持长连接,断开重连,设立接口向外界传输数据等等一整套的使用方法
由于前面亲测,GCDAsyncSocket不支持IPV6协议,所以本Demo是基于AsyncSocket封装的,想使用的GCDAsyncSocket的朋友可以照着Demo中的单例重新写一个,用法一模一样。
//
// XMSocketManager.h
// socket_tutorial
//
// Created by 王续敏 on 16-3-12.
// Copyright (c) 2016年 王续敏. All rights reserved.
//
#import <Foundation/Foundation.h>
#import "AsyncSocket.h"
#import <UIKit/UIKit.h>
#import "SmartWatch.pb.h"
enum{
SocketOfflineByServer,
SocketOfflineByUser,
};
@protocol ProtocolsDelegate <NSObject>
/**
* 发送数据到控制器,单例方法,runloop时,只能有一处在使用这个方法,然后处理全局的数据
*
* @param protocols 数据包
*/
- (void)sendDataToViewcontroller:(Protocols *)protocols;
@optional
/**
* socket的连接状态
*
* @param connectState yes 连接 / no 未连接
*/
- (void)socketConnectState:(BOOL)connectState;
@end
@interface XMSocketManager : NSObject
{
@public UInt64 _mobileID;
@public UInt64 _watchID;
}
@property (nonatomic, weak) id delegate;
@property (nonatomic, strong) AsyncSocket *socket; // socket
@property (nonatomic, copy ) NSString *socketHost; // socket的Host
@property (nonatomic, assign) UInt16 socketPort; // socket的port
@property (nonatomic, retain) NSTimer *connectTimer; // 定时器
@property (nonatomic, retain) NSData * sourceData;
@property (nonatomic, assign) BOOL connectState;//socket连接状态
@property (nonatomic, assign) BOOL isAcceptData;//是否接受到服务器回调的信息
+ (XMSocketManager *)sharedInstance;
/**
*socket连接
*/
- (void)socketConnectHost;
/**
*断开socket连接
*/
- (void)cutOffSocket;
/**
*@author 王续敏, 16-03-22 09:52:40
*@param protcols protocol
*传入参数 完成发送数据
*/
- (void)writeDataToServerWith:(Protocols *)protcols;
/**
*@author 王续敏, 16-03-22 09:52:40
*@param protcos protocol
*字节序
*/
- (NSMutableData *)byteOrderWithProtobuf:(Protocols *)protcos;
/**
* 开始心跳
*
* @param mobileID 手机ID
* @param watchID 当前手表的ID
*/
-(void)startConnectToSocketWithMobileID:(UInt64)mobileID WatchID:(UInt64)watchID;
@end
代码具体的使用,请移步github下载Demo,里边有详细的使用方法,如果有什么问题,欢迎留言探讨
下载地址