【问题标题】:how to send a buffer or byte array in a MQTT using nodeJS and protobufjs如何使用 nodeJS 和 protobufjs 在 MQTT 中发送缓冲区或字节数组
【发布时间】:2014-04-03 12:32:02
【问题描述】:

我有一个 nodejs (node v0.10.26) MQTT 代码,它将字符串发布到远程 MQTT 服务器上的主题。现在我正在尝试将字节数组和缓冲区发布到同一主题,但出现错误 代码:

var ProtoBuf = require("protobufjs");
var mqtt = require('mqtt');
var builder = ProtoBuf.loadProtoFile('event.proto'),
    as2 = builder.build('as2'),
    Message=as2.Message;

var message = new Message({
    "message_type": "EMOTICON"
});
console.log("message : "+message);
var buffer_message= message.encode();
client = mqtt.createClient(1883,'hostNameOfMQTT',{ encoding: 'binary' });
client.publish('NewTopic',buffer_message);
client.on('connect', function() {
    console.log("Message published : "+buffer_message);
     client.end();
});

我在执行时收到此错误 node.exe 示例Mqtt.js

C:\node>node.exe SimpleMQTT.js 消息:.as2.Message

C:\node\node_modules\mqtt\lib\generate.js:178 长度 += Buffer.byteLength(payload);

                 ^
TypeError: Argument must be a string
    at Object.module.exports.publish (C:\node\node_modules\mqtt\lib\
generate.js:178:22)
    at Connection.eval [as publish] (eval at <anonymous> (C:\node\no
de_modules\mqtt\lib\connection.js:58:29), <anonymous>:2:26)
    at MqttClient._sendPacket (C:\node\node_modules\mqtt\lib\client.
js:430:20)
    at MqttClient.<anonymous> (C:\node\node_modules\mqtt\lib\client.
js:105:12)
    at MqttClient.EventEmitter.emit (events.js:117:20)
    at MqttClient._handleConnack (C:\node\node_modules\mqtt\lib\clie
nt.js:498:10)
    at Connection.<anonymous> (C:\node\node_modules\mqtt\lib\client.
js:191:10)
    at Connection.EventEmitter.emit (events.js:95:17)
    at Connection._write (C:\node\node_modules\mqtt\lib\connection.j
s:187:12)
    at doWrite (_stream_writable.js:226:10)

但是,当我尝试发布 buffer_message.tostring() 时,我将对象详细信息作为字符串而不是实际的 ArrayBuffer? client.publish('AnkitTopic',buffer_message.toString()); 输出 toString() -> ByteBuffer(offser=0,markedOffSet=-1,length=2,capacity=16)

我不想要字符串,我希望通过 MQTT 传输实际的 byteBuffer。

有人,请建议我该怎么做!我猜它并不难获得,在java中是可能的,那么为什么不是在nodeJS中呢?

【问题讨论】:

    标签: node.js mqtt protocol-buffers


    【解决方案1】:

    您能否尝试发送另一种二进制内容(例如文件)来查看它是否有效?

    最新的 MQTT.js 版本支持二进制负载 https://github.com/adamvr/MQTT.js/issues/109

    【讨论】:

      【解决方案2】:

      我找到了解决这个问题的方法,希望对其他人有所帮助:

      我们可以为发送到 MQ 的每个有效负载附加一个标头,对其进行编码,最终的有效负载应该看起来相似(这就是我们将其转换为字节缓冲区的方式):

          var headerLengthBuffer = new ByteBuffer();
          var headerBuffer = header.encode();
          var messageLengthBuffer = new ByteBuffer();
          var messageBuffer = event1.encode();
      
          headerLengthBuffer.writeVarint32(headerBuffer.length);
          messageLengthBuffer.writeVarint32(messageBuffer.length);
      
          //Create the payload object
          var payload = headerLengthBuffer.toBuffer() + headerBuffer.toBuffer()+ messageLengthBuffer.toBuffer() + messageBuffer.toBuffer() ;
      
          return payload;
      

      上面创建的payload很容易发布,也被MQ接受。

      【讨论】:

        【解决方案3】:

        protobufjs 包支持原生 node.js 缓冲区。

        根据protobufjs/message API,您只需调用 message.toBuffer()。

        这是一个工作示例:

        var ProtoBuf = require("protobufjs");
        var mqtt = require('mqtt');
        var builder = ProtoBuf.loadProtoFile('company.proto'),
            Company = builder.build('Company'),
            Employee = Company.Employee;
        
        var employee = new Employee("James Bond", 007);
        
        var buffer_message = employee.toBuffer();
        
        var client = mqtt.connect('mqtt://test.mosquitto.org');
        
        client.on('connect', function() {
           client.publish('MyCompany', buffer_message);
           client.end();
        });

        使用以下 company.proto 文件:

        package Company;
        
        message Employee{
            optional    string      name = 1; 
            optional    uint32      id = 2;
        }
        

        【讨论】:

          猜你喜欢
          • 2023-01-27
          • 2011-07-09
          • 2019-01-01
          • 1970-01-01
          • 2016-04-14
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          相关资源
          最近更新 更多