当前位置: 首页
编程语言
PHP Protobuf扩展安装指南与使用方法详解

PHP Protobuf扩展安装指南与使用方法详解

热心网友 时间:2026-05-08
转载

所用资源

本教程实践基于GitHub上开源的高效序列化工具:allegro/php-protobuf。该项目为PHP语言提供了完整的Protocol Buffers支持。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

prodected php,安装php的php-protobu扩展及使用

安装PHP的protobuf扩展

安装PHP的protobuf扩展步骤非常标准,与安装其他PHP扩展流程基本一致。首先进入解压后的扩展源码目录,然后按顺序执行以下命令:

phpize

./configure

make

make install

编译安装完成后,最关键的一步是在你的php.ini配置文件中添加一行扩展声明:

extension=protobuf.so

请务必记得重启你的PHP服务(例如PHP-FPM或Apache)。之后,通过创建一个phpinfo()页面进行验证,就能看到protobuf扩展已经成功加载并启用了。

如何使用?

第一步:定义与生成

首先,你需要创建一个.proto文件来定义你的数据结构格式。例如,我们创建一个名为foo.proto的文件,其内容如下:

message PhoneNumber {
required string number = 1;
required int32 type = 2;
}

message Person {
required string name = 1;
required int32 id = 2;
optional string email = 3;
repeated PhoneNumber phone = 4;
}

message AddressBook {
repeated Person person = 1;
}

数据结构定义完成后,使用allegro/php-protobuf项目提供的PHP脚本生成对应的PHP类文件:

php protoc-php.php foo.proto

执行成功后,你将得到一个名为pb_proto_foo.php的PHP文件。该文件包含了根据proto定义自动生成的PHP类,后续所有的序列化与反序列化操作都将依赖这些类。

第二步:应用实践

接下来我们通过具体场景来学习如何使用。假设我们需要与一个Java后端服务进行基于Protobuf的数据通信。

场景一:解析Java端传来的Buffer数据

当Java服务返回了一个经过序列化的protobuf二进制数据流时,在PHP端可以按以下方式解析:

require_once 'pb_proto_test.php'; // 引入之前生成的PHP类文件
$packed = curlGet('http://10.0.247.113:8080/testweb/proto'); // 此处模拟从Java端获取的二进制数据
$foo = new AddressBook();
try {
$foo->parseFromString($packed); // 核心解析方法,将二进制流反序列化为对象
} catch (Exception $ex) {
die('Parse error: ' . $e->getMessage()); // 解析出错时的异常处理
}
$pb = $foo->getPerson(); // 获取Person对象列表
// 可以打印整个数组查看结构:print_r($pb);
// 或者仅打印第一个元素:print_r($pb[0]);
// 在实际业务中,直接访问对象的Getter方法即可:
echo $pb[0]->getName() .' _ '.$pb[0]->getId() .' _ ';
print_r($pb[0]->getPhone());

场景二:PHP生成并修改Buffer数据

反之,PHP端也可以构造数据对象,将其序列化为二进制Buffer后发送给其他服务:

require_once 'pb_proto_test.php';
$foo = new Person();
$foo->setName('xiaojh');
$foo->setId(200);
$foo->setEmail('dofound@163.com');
// 如果需要添加重复字段(例如phone),可以使用append方法://$foo->appendPhone(2);
$packed = $foo->serializeToString(); // 核心序列化方法,得到二进制Buffer
$foo->clear(); // 清空对象状态,以便重复使用
try {
$xiao = $foo->parseFromString($packed); // 可将序列化后的数据再次解析回来,用于验证
// print_r($xiao);
} catch (Exception $ex) {
die('Upss.. there is a bug in this example');
}
echo $foo->getName();
echo $foo->getPhone()->number;
$foo->dump(); // 部分生成类会提供dump方法,便于调试时查看对象内容

PHP内部调用

------------------------------
生成buffer数据

来源:https://blog.csdn.net/weixin_39957805/article/details/116003120

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
PHP 8.3表单验证教程与用户输入数据校验方法

PHP 8.3表单验证教程与用户输入数据校验方法

需要明确一个核心事实:PHP 8 3 版本仍然没有内置一个完整的“表单验证框架”。这意味着,开发者处理用户提交的数据时,filter_var() 和 filter_input() 函数依然是核心工具,但需要手动组合验证规则、执行数据清洗与校验。整个过程需要清晰的逻辑设计,它无法自动绑定表单字段或返回

时间:2026-05-08 13:10
Ubuntu Node.js内存泄漏问题排查与日志分析指南

Ubuntu Node.js内存泄漏问题排查与日志分析指南

在Ubuntu服务器上运行Node js应用时,内存泄漏是影响性能与稳定性的常见问题。通过系统性地分析应用日志,我们可以高效定位泄漏根源。本文将详细介绍一套从监控到诊断的完整排查流程,帮助您彻底解决Node js内存泄漏难题。 第一步:准备排查环境与工具 开始排查前,请确保基础环境配置正确。首先,在

时间:2026-05-08 13:10
Go语言中Writer与Reader接口的桥接实现方法

Go语言中Writer与Reader接口的桥接实现方法

在 Go 语言开发中,经常需要将数据从 io Writer 流向 io Reader。无论是将 HTML 渲染结果直接作为 HTTP 请求体发送,还是实现流式数据处理,掌握 bytes Buffer 与 io Pipe 这两种核心桥接方案,是编写高效、优雅 Go 代码的关键。 Go 语言的 I O

时间:2026-05-08 13:10
Python字符串strip方法详解如何删除指定字符而非子串

Python字符串strip方法详解如何删除指定字符而非子串

Python的strip()方法并非删除指定子串,而是将参数视为字符集合,从字符串两端连续删除集合内的字符,直至遇到非集合字符即停止。该方法仅处理字符串首尾,不影响中间内容,且返回新字符串。如需精确移除前缀或后缀,应使用removeprefix()、removesuffix()或切片操作。

时间:2026-05-08 13:09
XAMPP多端口配置与KeepAlive性能优化指南

XAMPP多端口配置与KeepAlive性能优化指南

在XAMPP环境中配置多端口并优化KeepAlive参数,是提升本地开发效率的关键步骤。然而,许多开发者在实际操作中常因忽略配置细节而陷入误区,导致服务不稳定或性能未达预期。本文将深入解析XAMPP多端口设置与KeepAlive调优的核心要点,帮助您避开常见陷阱,实现高效稳定的本地服务器环境。 多端

时间:2026-05-08 13:09
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程