试图使用Ionic 4中的协议缓冲区进行编码
我已经下载了协议并用它来生成一堆_pb.js文件,每个. proto文件一个。很好。
首先关注原型示例。这是示例代码:
import { load } from "protobufjs"; // respectively "./node_modules/protobufjs"
load("awesome.proto", function(err, root) {
if (err)
throw err;
// example code
const AwesomeMessage = root.lookupType("awesomepackage.AwesomeMessage");
let message = AwesomeMessage.create({ awesomeField: "hello" });
console.log(`message = ${JSON.stringify(message)}`);
let buffer = AwesomeMessage.encode(message).finish();
console.log(`buffer = ${Array.prototype.toString.call(buffer)}`);
let decoded = AwesomeMessage.decode(buffer);
console.log(`decoded = ${JSON.stringify(decoded)}`);
});
我做了一些更改以匹配我的文件。更改proto文件的名称。但是我的proto文件中没有包名称。所以我只是使用了消息名称。首先这是我的. proto文件的开头:
syntax = "proto3";
import "constants.proto";
import "wifi_constants.proto";
message CmdScanStart {
bool blocking = 1;
bool passive = 2;
uint32 group_channels = 3;
uint32 period_ms = 4;
}
message RespScanStart {
}
message CmdScanStatus {
}
message RespScanStatus {
bool scan_finished = 1;
uint32 result_count = 2;
}
下面是我修改后的代码:
load("../../assets/proto/wifi_scan.proto", function(err, root) {
if (err)
throw err;
// example code
const AwesomeMessage = root.lookupType("RespScanStatus");
let message = AwesomeMessage.create({ scan_finished: 1, result_count: 31 }); // uint32 result_count
console.log(`message = ${JSON.stringify(message)}`);
let buffer = AwesomeMessage.encode(message).finish();
console.log(`buffer = ${Array.prototype.toString.call(buffer)}`);
let decoded = AwesomeMessage.decode(buffer);
console.log(`decoded = ${JSON.stringify(decoded)}`);
});
这似乎不起作用。我的控制台显示:
[ng] [console.log]: "message = {}"
[ng] [console.log]: "buffer = "
[ng] [console.log]: "decoded = {}"
我相信我已经成功地定位到文件并选择了一个有效的消息名称。但是如果我有一个引用其他原型文件的原型文件。运行时如何解决这个问题?我认为使用预构建的_pb.js文件会更有意义。什么是awesomepackage?我的原型文件没有包!为什么不停地引用很棒的东西?不棒:令人困惑!
此代码看起来可以直接使用。原型文件。但你不需要protoc来做这件事吗?这不一定可用。如果你知道发生了什么,这可能看起来很明显,但对我来说,这并不完全一致。请帮忙。
一个可能的答案是使用谷歌protobuf。看见https://github.com/protocolbuffers/protobuf/tree/master/js
$ npm install google-protobug --save
现在根据问题,使用protoc生成一组\u pb。js文件。运行命令时,请选择常见的JS导入样式,以便下一步与输出对齐:
$ protoc --proto_path=./proto-src-wifi/ --js_out=import_style=commonjs,binary:./proto-js ./proto-src-wifi/wifi_scan.proto
这将创建一个_pb.js文件,您现在可以在角项目中使用这些文件。我发现这样的东西可以很好地一次生成堆:
$ protoc --proto_path=./proto-src-wifi/ --js_out=import_style=commonjs,binary:./proto-js ./proto-src-wifi/*.proto
您可以使用以下方式导入它们wifi_scan_pb:
console.log('armpit!');
var messages = require("../../assets/js/wifi_scan_pb");
var message = new messages.RespScanStatus();
message.setScanFinished(true);
message.setResultCount(31);
var bytesOfStuff = message.serializeBinary();
console.log(`bytesOfStuff = ${JSON.stringify(bytesOfStuff)}`);
var messageRecovered = messages.RespScanStatus.deserializeBinary(bytesOfStuff);
console.log(`Recovered Scan finished = ${messageRecovered.array[0]}`);
console.log(`Recovered Scan Result Count = ${messageRecovered.array[1]}`);
您需要检查\u pb文件,以获得您需要为正在构建的对象中的每个条目使用的方法的确切名称:“setscanfished”或其他。。。
组件上方:
declare var require: any;
完成任务!
问题内容: 我正在使用gSoap将旧式C 系统重构为SOA。我们遇到了一些性能问题(非常大的XML),因此我的领导要我看一下协议缓冲区。我做到了,它看起来非常酷(我们需要C 和Java支持)。但是协议缓冲区是仅用于序列化的解决方案,现在我需要将其发送到Java前端。从C ++和Java角度来看,我应该使用什么来通过HTTP(只是内部网络)发送那些序列化的内容? PS。另一个人试图加速我们的gSoa
我目前在我的protoc.exe.旁边有一个名为addressbook.proto的文件,我在生成. h和. cc文件时遇到了困难 然而,我得到以下回应 关于我可能做错了什么有什么建议吗?
据我所知,协议缓冲区主要用于控制服务器和客户端代码的项目。我的一般问题是——协议缓冲区能否用于将二进制消息序列化/反序列化到使用现有协议的服务器?所以,我的问题: > 如果协议缓冲区不支持本机微调现有协议的序列化/反序列化方式,那么可以通过扩展添加该功能吗?是否可以以某种方式添加序列化/反序列化方法可以识别的关键字?也许这可以通过扩展或修改protobuf csharp port或protobuf
问题内容: 我正在尝试在Linux平台上探索协议缓冲区(PB),我的编码语言是C ++。我在协议缓冲区在线文档中找到了示例,但没有特定于套接字发送和接收的内容(或者我完全错过了:))。因此,我决定在实际消息之前添加消息Length,并通过套接字发送它。如果有人可以提出比我计划做的更好的解决方案,并且在PB中已经准备好任何用于创建此类数据包的东西,我将不胜感激。 但是我仍然在服务器端遇到问题,必须对
在阅读这个相当长的问题之前,我提出了一个bughttps://github.com/GoogleCloudPlatform/python-docs-samples/issues/1103. 原型包和名称解析的留档状态 您可以使用其他定义。通过导入原始文件。导入另一个。在proto的定义中,您可以在文件的顶部添加一条import语句。 我的依赖于annotations.proto将HTTP/JSON
请注意:虽然这个问题特别提到了Dropwizard,但我相信任何有泽西/JAX-RS经验的人都应该能够回答这个问题,因为我可以想象Dropwizard只是在幕后遵循泽西/JAX-RS约定。 我有一个Dropwizard服务,它用JSON编写,工作非常出色。 现在我想将其切换为读/写二进制数据(以最小化网络带宽)。我看到了Dropwizard Protobuf库,但我对在Dropwizard中实现二