我试了3天通过WSS连接到SAP MQTT(wss://iotmmsXXXXXXX.hana.ondemand.com/com.sap.iotservices.mms/v1/api/ws/mqtt)。
我使用的是p12客户端证书。
但它会在握手时/握手后卡住(参见Wireshark图片)。
x1c 0d1x 10.XX.XX.XXX是我的IP
155.XX.XX.XXX是SAP IP
30秒后,我得到了这个错误:
然后他又试着连接。
这里是来源:
const fs = require('fs');
const mqtt = require('mqtt');
// Parts of URL and Path
const hcp_account_id = 'WWWWWWWWW';
const hcp_landscape_host = '.hana.ondemand.com' // this is used on PROD with Client Certificate Authentication
const my_endpoint_url_path = '/com.sap.iotservices.mms/v1/api/ws/mqtt';
//Certificate
const client_p12 = "./YYYYYYYY-YYYY-YYYY-YYYY-YYYYYYYYYYYY.p12";
// the following values need to be taken from the IoT Cockpit
const device_id = 'XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX';
const message_type_id_From_device = 'ZZZZZZZZZZZZZZZZZZZZ';
// for down- upstream communication
var my_publish_topic = "iot/data/" + device_id;
var my_subscription_topic = "iot/push/" + device_id;
var my_endpoint = "iotmms" + hcp_account_id + hcp_landscape_host;
var wsoptions =
{
host: my_endpoint,
port: 443,
pfx: fs.readFileSync(client_p12),
passphrase: 'AAAAA',
checkServerIdentity: false,
protocol: 'mqttv3.1',
protocolVersion: 13,
perMessageDeflate: true,
client_max_window_bits: true
}
var options =
{
wsOptions: wsoptions,
clientId: device_id,
protocolId: 'MQIsdp',
protocolVersion: 3,
protocol: 'wss',
hostname: my_endpoint,
port: 443,
path: my_endpoint_url_path
}
const mqttc = mqtt.connect(options);
mqttc.subscribe(my_subscription_topic, 0);
mqttc.on('connect', () => console.log('connected!'));
mqttc.on('error', (msg) => console.log('error: ' + msg));
mqttc.on('offline', (msg) => console.log('offline: ' + msg));
mqttc.on('close', (msg) => console.log('close: ' + msg));
// message is Buffer
mqttc.on('message', (topic, message) => console.log('message(' + topic + '): ' + message.toString()));
字符串
1条答案
按热度按时间ldxq2e6h1#
我已经解决了这个问题,将“mqtt/lib/client.js”中的“sendPacket”方法更改为
字符串