为了通过线路将复杂的JSON / JavaScript对象发送到C ++二进制文件,我使用的是Protocol Buffers。现在有针对Node.js的原生protobuf支持,所以我没有使用任何其他绑定。
// Set maximum execution time of binary to equal the
// remainder of processing time, minus a second to allow
// for parsing.
var timeLimit = context.getRemainingTimeInMillis() - 1000;
// Check if meta parameters are given in the request.
// Assign default values if they are not.
var model = new protocols.Model();
// Sort the resolutions.
function descending(a, b) {
if (a.width > b.width) {
return -1;
} else if (a.width < b.width) {
return 1;
}
return 0;
}
// Construct image objects.
var images = request.images.map(function(image) {
// Perform the sort.
image.resolutions.sort(descending);
// Create an image protobuffer.
var imageProto = new protocols.Model.Image();
// Assign the original's resolution to the image.
imageProto.setWidth(image.resolutions[0].width);
imageProto.setHeight(image.resolutions[0].height);
// Return the result.
return imageProto;
});
// Construct flag enumeration references.
var flags = request.flags.map(function(flag) {
return protocols.Model.Flag[flag];
});
// Assign request properties to protobuf.
model.setImagesList (images );
model.setFlagsList (flags );
model.setMinNoOfPages (request.minNoOfPages ? request.minNoOfPages : 1 );
model.setMaxNoOfPages (request.maxNoOfPages ? request.maxNoOfPages : 1 );
model.setMaxPerPage (request.maxPerPage ? request.maxPerPage : 5 );
model.setPageWidth (request.pageWidth ? request.pageWidth : 3508 );
model.setPageHeight (request.pageHeight ? request.pageHeight : 2480 );
model.setTimeLimit (request.timeLimit ? request.timeLimit : timeLimit );
model.setBorderWidth (request.borderWidth ? request.borderWidth : 0 );
model.setMinDim (request.minDim ? request.minDim : 0 );
// This is where things go wrong.
var serialized = model.serializeBinary();
fs.writeFileSync('model.pb', serialized);
var read = fs.readFileSync('model.pb'),
model2 = protocols.Model.deserializeBinary(read);
console.log(model.toObject());
console.log(model2.toObject());
以上是我坚持的代码。我设法编译了一个protobuf消息:
syntax = "proto3";
package layout;
message Model {
enum Flag {
FILL_PAGE = 0;
BORDERS = 1;
}
message Image {
int32 width = 1;
int32 height = 2;
}
repeated Flag flags = 1;
repeated Image images = 2;
string avoid_layout = 3;
int32 min_no_of_pages = 4;
int32 max_no_of_pages = 5;
int32 max_per_page = 6;
int32 page_width = 7;
int32 page_height = 8;
int32 time_limit = 9;
int32 border_width = 10;
int32 min_dim = 11;
}
但是,有关protobuf的JavaScript支持的文档很少(https://developers.google.com/protocol-buffers/docs/reference/javascript-generated#message),我无法弄清楚如何将消息读取到文件中,然后再次阅读它们。有人可以向我解释如何做到这一点?
我想解决方案是我代码最后几行的一些变化,但目前我收到了这个错误:
AssertionError: Failure: Type not convertible to Uint8Array.
答案 0 :(得分:3)
您可能正在目睹节点未被识别为
Buffer
的一些模糊情况。我找到了relevant issue report。因此,尝试使用
Uint8Array
或replacing the constructor。该建议与您的建议特别相似 - 它也在读取二进制文件。