NodeJS 下protobuf.js 的应用

nodeJS 下使用google 的protobuf 实现消息的序列化/反序列化异常的简单,连proto文件的预编译都不需要。没有必要使用protoc 工具将proto 文件转换成JavaScript的程序。直接使用proto文件。

安装

$> npm install protobufjs [--save --save-prefix=~]

proto 文件

syntax = "proto3";
package websocket;

message WebsocketMessage {
    string Topic =1;
    bytes  Body=2;
 }
message GenericRPC {
    string Method =1;
	string From =2;
	string To=3;
	int32 Code=4;
    bytes  parameters=5;
 } 

测试程序

var protobuf = require("protobufjs");
protobuf.load("./CoreMessage.proto", function(err, root) {
    if (err)
        throw err;
 
    // Obtain a message type
    var WebsocketMessage = root.lookupType("websocket.WebsocketMessage");
 
    // Exemplary payload
    var payload = { Topic: "weatherstation1.RPC",Body:new Buffer("hello the world") };
   
    // Verify the payload if necessary (i.e. when possibly incomplete or invalid)
    var errMsg = WebsocketMessage.verify(payload);
    if (errMsg)
        throw Error(errMsg);
 
    // Create a new message
    var message = WebsocketMessage.create(payload); // or use .fromObject if conversion is necessary
 
    // Encode a message to an Uint8Array (browser) or Buffer (node)
    var buffer = WebsocketMessage.encode(message).finish();
    // ... do something with buffer
 
    // Decode an Uint8Array (browser) or Buffer (node) to a message
    var message = WebsocketMessage.decode(buffer);
    // ... do something with message
     console.log("Topic:"+message.Topic);
     console.log("Body:"+message.Body)
    // If the application uses length-delimited buffers, there is also encodeDelimited and decodeDelimited.
  
});

方便吧?我的软件是调试通过。

你可能感兴趣的:(protobuf,NodeJS)