主要步骤:
定义user.proto消息类型
编译成浏览器可运行的proto文件
在浏览器使用user.js生成Protobuf对象
序列化为二进制 data
发送 data 到PHP
PHP使用Protobuf库解析二进制数据,反序列化为User对象
从User对象中取出字段值
1、下载google的protobuf的compiler,通过编译器可以将.proto文件转换为想要的语言文件。
下载地址:https://repo1.maven.org/maven2/com/google/protobuf/protoc/
我使用这个
2、新建一个user.proto:
syntax = "proto3";3、转换
message User {
string name = 1;
int32 age = 2;
}
protoc-4.0.0-rc-2-windows-x86_64 --js_out=import_style=commonjs,binary:. user.proto生成user_pb.js,如果是node.js的话就直接可以使用了,但是想在浏览器中使用还需要做一些处理
4、安装相关的nodejs库
npm install -g require(对库文件的引用库)5、新建一个exports.js
npm install -g browserify(这个是用来打包成前端使用的js文件)
npm install google-protobuf
var UserBody = require('./user_pb');6、打包成浏览器可运行的js,执行命令
module.exports = {
DataProto: UserBody
}
browserify exports.js > UserBody.js7、生成的UserBody就可以在浏览器使用了
<!DOCTYPE html>8、后端php
<html>
<head>
<meta charset="UTF-8">
<script type="text/javascript" src="//repo.bfw.wiki/bfwrepo/js/UserBody.js"></script>
<script type="module">
// 引入proto.js
var Msg = proto.User;
var msg = new Msg();
msg.setName('John');
var data = msg.serializeBinary();
var xhr = new XMLHttpRequest();
xhr.open('POST', 'your.php');
xhr.send(data);
</script>
</head>
<body>
</body>
</html>
<?php
require 'vendor/autoload.php';
use Protobuf\Message;
class User extends Message {}
// 处理Protobuf请求
$data = file_get_contents('php://input');
$user = User::parseBinary($data);
$name = $user->getName();
$age = $user->getAge();
网友回复
python如何调用openai的api实现知识讲解类动画讲解视频的合成?
html如何直接调用openai的api实现海报可视化设计及文本描述生成可编辑海报?
f12前端调试如何找出按钮点击事件触发的那段代码进行调试?
abcjs如何将曲谱播放后导出mid和wav格式音频下载?
python如何将曲子文本生成音乐mp3或wav、mid文件
python中mp3、wav音乐如何转成mid格式?
js在HTML中如何将曲谱生成音乐在线播放并下载本地?
python如何实现在windows上通过键盘来模拟鼠标操作?
python如何给win10电脑增加文件或文件夹右键自定义菜单?
python如何将音乐mp3文件解析获取曲调数据?