在iOS中Protocol Buffer(v3.3.0)的使用

在iOS中Protocol-Buffer-v3-3-0-的使用

Posted by cl9000 on August 14, 2017

在此仅做笔记记录,以便后期查阅,如有问题,及时联系,多谢大家审阅。

一、Protocol Buffer

最新版本Protobuf3.3.0 在iOS中的使用(OC与Swift使用一样)
具体使用参考官方文档(需要翻墙)

protocol buffers是一种灵活,高效,自动化的结构化数据序列化机制。类似于我们现在使用的XML和JSON。是Google公司推出出的。但是(__但是__的前面都他妈是废话)与传统的XML和JSON不同的是,它是一种二进制格式,免去了文本格式转换的各种困扰,并且转换效率非常快,由于它的跨平台、跨编程语言的特点,它越来越普及,尤其是网络数据交换信息量较大方面使用起来更加便利。

Protobuf是一种平台无关、语言无关、可扩展且轻便高效的序列化数据结构的协议,可以用于网络通信和数据存储。

PB目前托管在GitHub

链接地址:
https://github.com/google/protobuf
或者https://github.com/google/protobuf/releases(尽量选择后者,找到你所需的语言安装包)
源码的主要功能可以分为两部分:

1、PB编译器:源码生成器,将PB格式定义文件**.proto(PB数据格式的一种定义文件)转换为对象源码(支持C++,JAVA,Python,Objective-C,Javascript,PHP等格式),主要使用命令行操作。
2、PB基础库:完成序列化与反序列化转换过程的支持

  • 对 象 **>>>>**二进制(序列化)
  • 二进制 **>>>>**对 象(反序列化)
    *(把 对象转换为字节序列 的过程称为 对象的序列化;把 字节序列恢复为对象 的过程称为 对象的反序列化。)

三、Protoc 编辑器环境配置

配置protobuf编译器

首先将文件下载下来https://github.com/google/protobuf/releases

1、 配置protobuf编译器环境

打开终端执行命令进入到文件的根目录:
$ cd protobuf-3.3.0
然后依次执行:
$ ./configure
$ make
$ make check
$ sudo make install
检测安装完毕-使用命令:
$ protoc --version 或者查看帮助$ protoc -h
如果编译顺利的话,便可以使用protoc命令了,以后便可以用这个命令将.proto文件转换为不同语言的源代码文件了。

2、使用PB编译器编译.proto文件

安装好PB,使用PB编译器来生成我们需要的数据类型文件。
在桌面touch个文件夹名为Class,
$ cd desktop -> $ touch Class -> $ cd Class

在空文件夹Class 创建一个Person.proto文件(名字自定义)
$ touch Person.proto

创建好后就定义一些数据类型(使用终端或编辑器都可以)
按照官方标准语法https://developers.google.com/protocol-buffers/ 编写通用代码
文件中写入:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
syntax = "proto3";

message Person {
string name = 1;
int32 uid = 2;
string email = 3;
enum PhoneType {
MOBILE = 0;
HOME = 1;
WORK = 2;
}
message PhoneNumber {
string number = 1;
PhoneType type = 2;
}
repeated PhoneNumber phone = 4;
}

保存退出,命令行确保在Class文件夹中,执行命令:
$ protoc *.proto --objc_out=../Class

若没问题,这是文件夹中应该已经生成了model文件。
若报错,1、请检查命令;2、检测***.proto文件中的标点符号;

3、引入iOS工程

<1> 一种使用Pod方式引入

新建工程PBDemo,终端执行:
$ cd PBDemo

创建 Podfile文件
$ touch Podfile

编辑 Podfile文件
$ vim Podfile
进入文件后点击键盘(英文输入法) i 进入 __insert__状态 开始编辑(注意标点符号

1
2
3
4
5
platform :ios,'8.0'
target 'PBDemo' do
truepod 'Protobuf','~>3.3.0'
end
`

然后执行保存, 点击esc 输入 :wq,回车。
注意上面的 pod 'Protobuf','~>3.3.0' 否则没有3.3.0版本,以后若有新版本,可先使用 $ pod search Protobuf查询下。
使用Pod来导入库
$ pod install
完成后退出工程,再次进入就会看到PB依赖库了。以后使用的时候切记如下两点:
① 从此以后需要使用Cocoapods生成的 .xcworkspace文件来打开工程,而不是使用以前的.xcodeproj文件。
② 每次更改了Podfile文件,都需要重新执行一次pod update命令。

补充: 执行 pod install 后,除了Podfile,还会生成一个名为
Podfile.lock 的文件,它会锁定当前各依赖库的版本,之后即使多次执行pod install也不会更改版本,只有执行pod update才会改变Podfile.lock,这在多人协作的时候,这样也可以防止第三方库升级时候造成大家各自的第三方库版本不一致。所以在提交版本的时候不能把它落下,也不要添加到.gitignore中。(转)

pod install 完后重新打开 PBDemo**.xcworkspace** 工程,
将编译好的PB文件引入工程,如图:

接着,生成的文件是不支持ARC,需要手动转一下

点击工程—Build Phases —Compile Source 中的Person.pbobjc.m文件添加-fno-objc-arc保存变编译suc。
如图:

到此,使用Pod引入ProtocolBuffer就完了,就是一些测试了,如下:

在ViewController中引入 Person.pbobjc.h 头文件
加入测试代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
// 创建对象
Person *person = [Person new];
person.name = @"weiCL";
person.uid = 20170810;
person.email = @"cl9000@126.com";

// 序列化为Data
NSData *data = [person data];
NSLog(@"NSData= %@", data);

// 反序列化为对象
Person *person2 = [Person parseFromData:data error:NULL];
NSLog(@"name:%@ uid:%d email:%@",person2.name,person2.uid,person2.email);

OK,下一种方式直接引入经常会出现的错误,解决方法具体请看下面

<2>另一种方式直接将相关类文件拖入工程

  1. 新建一个工程PBDemo3,show in Finder 创建文件夹名称为:protocolbuf (此名称可自定义,但后面面要使用其路径),和创建个Lib文件夹备用

  2. 打开下载好的protobuf-3.3.0(或最新版本),会有个objectivec的文件夹。拷贝里面所有的文件,放到上面创建的protocolbuf 文件夹中。

  3. 使用Xcode打开工程,将Lib文件夹引入工程,然后选中Lib文件夹,点击左下角“+”(Add Files to PBDemo3), 引用protocolBuffer源文件到工程中
    (源文件里面有两个工程配置文件:ProtocolBuffers_iOS.xcodeproj和ProtocolBuffers_OSX.xcodeproj,引用ProtocolBuffers_iOS.xcodeproj就好)。这里我们只引入库文件,另创建Lib文件只是为了方便管理。

  4. 选中工程: targets —> Build Phases —> Link Binary With Libraries, 引用源码静态库文件:libProtocolBuffers.a

  5. 在工程设置搜索静态库的头文件(pb文件在protocolbuf文件夹里面):
    targets —> Build Setting —> Search Paths —> Header Search Paths, 写入:$(PROJECT)/protocolbuf

    完成后 build 一下,success

6、 将我们上面通过PB编译器生成的数据模型文件Class文件夹(内含Person.proto,Person.pbobjc.h和Person.pbobjc.m)
拖入工程,(尽量使用Add File to …引入)
因为不支持arc, 所以需要在*.pbobjc.m设置-fno-objc-arc, 然后就可以使用了。具体目录如图:

Build一下、success 、进行测试、测试代码如上不重复了这里。

Refrence

IBM Google Protocol Buffer 的使用和原理
方式一:使用Pod
ProtocolBuffer for Objective-C 运行环境配置及使用
ProtocolBuffers-3 For Objective C (1)-简单的使用
方式二:直接引入
iOS之ProtocolBuffer搭建和示例demo



支付宝打赏 微信打赏

赞赏一下 坚持原创技术分享,您的支持将鼓励我继续创作!