AsyncSocketDemo,基于谷歌ProtocolBuffer协议的及时通讯

翁凯定
2023-12-01

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,里边有详细的使用方法,如果有什么问题,欢迎留言探讨
下载地址

 类似资料: