• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    如何在PHP环境中使用ProtoBuf数据格式

    前言

      RPC是google公司主导的一款RPC框架,并使用protobuf作为数据传输格式,伴随gRPC框架的成熟及使用人群的增加,对于底层使用的数据格式protobuf也被越来越受到重视,而对于PHP生态而言,相关ProtoBuf介绍文档及使用资料比较少,故此写简文希望能帮助到一些有需要的同学。

      ProtoBuf (Google Protocol Buffer)是由google公司用于数据交换的序列结构化数据格式,具有跨平台、跨语言、可扩展特性,类型于常用的XML及JSON,但具有更小的传输体积、更高的编码、解码能力,特别适合于数据存储、网络数据传输等对存储体积、实时性要求高的领域。

      目前官方ProtoBuf 最新版本ProtoBuf3,已经支持多种语言:C++\C#\Go\Java\Python\Ruby\Object C \Javascript\PHP,并且提供工具很方便地根据不同语言产生ProtoBuf需要的类库。

      下面将通过Person数据格式作为示例进行描述如果在PHP环境中如何使用ProtoBuf3。

    一、定义一个消息类型

    创建一个关于Person的定义文件(以.proto为后缀),如示例为person.proto,文件内容如下:

    syntax="proto3";
    package test;
    message Person{
     string name=1;//姓名
     int32 age=2;//年龄
     bool sex=3;//性别
    }

    1、syntax="proto3":表明使用的是proto3格式,如果不指定则为proto2

    2、package test:定义包名为test,生成类时,会产生一个目录为test

    3、message Person:消息主体内容,里面为各个字段的定义

    二、生成对应的PHP类

    定义好Person的格式后,该格式如果不生成我们所需要的类库,其实是无任何意义的,还google提供一个工具protoc生成我们要的类库。

    1、安装protoc

    安装地址:protobuf-php-3.5.1.tar.gz,目前最新为3.5.1

    官方发布地址:https://github.com/google/protobuf/releases/tag/v3.5.1

    解压并安装:

    tar -zxvf protobuf-php-3.5.1.tar.gz
    cd protobuf-3.5.1
    ./configure --prefix=/opt/soft/protobuf
    make
    make install

    2、生成类库

    /opt/soft/protobuf/bin/protoc --php_out=./ person.proto

    生成后将在当前目录产生如下文件:

    GPBMetadata/Person.php

    Test/Person.php

    三、在PHP中使用ProtoBuf

    在PHP中使用ProtoBuf依赖一个protobuf的扩展,目前提供两种方式进行使用,1:php的c扩展,2:php的lib扩展包,这两者均可在刚才下载包里可以找到。

    另外,也可以使用composer进行安装该依赖扩展:composer require google/protobuf

    这里我主要是使用composer安装,应该它可以帮我产生autoload

    安装好依赖后,我们就可以开始在php环境下使用protobuf了

    1、序列化

    ?php
    include 'vendor/autoload.php';
    include 'GPBMetadata/Person.php';
    include 'Test/Person.php';
    
    $person = new Test\Person();
    $person->setName("lailaiji");
    $person->setAge("28");
    $person->setSex(true);
    $data = $person->serializeToString();
    file_put_contents('data.bin',$data);


    2、反序列化

    ?php
    include 'vendor/autoload.php';
    include 'GPBMetadata/Person.php';
    include 'Test/Person.php';
    $bindata = file_get_contents('./data.bin');
    $person = new Test\Person();
    $person->mergeFromString($bindata);
    echo $person->getName();

    可以正常地输出lailaiji

    PHP常用的使用方法:

    序列化:

    1、serializeToString:序列化成二进制字符串

    2、serializeToJsonString:序列化成JSON字符串

    反序列化:

    1、mergeFromString:二进制字符串反序列化

    2、mergeFromJsonString:Json字符串反序列化

    .proto的message解析

    1、定义:

    类型 变量名=位置;

    如:int32 age=1;

    这里需要区分,变量名后面的数字意义为该变量内容在二进制序列中的位置而不是变量的值,该数字必须是唯一不可重复使用。

    2、目前支持的类型:

    double,float,int32,int64,uint32 ,uint64,sint32,sint64

    fixed32,fixed64,sfixed32,sfixed64,bool,bytes

    性能测试

    https://github.com/eishay/jvm-serializers/wiki

    1、序列号+反序列号时间:

    image.png

    2、存储大小:

    image.pn

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

    您可能感兴趣的文章:
    • PHP const定义常量及global定义全局常量实例解析
    • PHP变量作用域(全局变量&局部变量)&global&static关键字用法实例分析
    • PHP global全局变量经典应用与注意事项分析【附$GLOBALS用法对比】
    • PHP中$GLOBALS与global的区别详解
    • php利用ob_start()清除输出和选择性输出的方法
    • PHP操作MySQL中BLOB字段的方法示例【存储文本与图片】
    • PHP编程文件处理类SplFileObject和SplFileInfo用法实例分析
    • PHP ob缓存以及ob函数原理实例解析
    上一篇:基于PHP实现堆排序原理及实例详解
    下一篇:PHP基于openssl实现非对称加密代码实例
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    如何在PHP环境中使用ProtoBuf数据格式 如,何在,PHP,环境,中,使用,