0
trie 3日からSAP MQTT over WSSに接続できません(wss://iotmmsXXXXXXXXX.hana.ondemand.com/com.sap.iotservices.mms/v1/ api/ws/mqtt)。WSS上でMQTTを使用してSAPサーバーに接続できません
これで私はp12クライアント証明書を使用しています。
しかし、それはハンドシェイク(Wiresharkピクチャを参照)の上/後につかまります。 そして、彼がしよう:
10.XX.XX.XXX
は私のIP155.XX.XX.XXXである私は、このエラーを得た30秒後にSAP IP
ですもう一度接続してください。ここで
はソースです:
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()));