NodeMCU 无法使用 TLS 连接到 Bluemix

NodeMCU fails to connect to Bluemix with TLS

我尝试将 NodeMCU 与 IBM Bluemix IoT Foundation 连接起来。不安全的 MQTT 连接工作出色,并将数据从 BMP180 推送到云端。但是,当我开始使用 TLS 时,它不会连接到代理。我尝试与 mqtt.fx 建立 TLS 连接并且工作正常,似乎 NodeMCU 是问题所在。 如果我 运行 此代码:

orgID="****"
BROKER = orgID..".<bluemix>"
BRPORT = 8883

CLIENTID = "d:"..orgID..":generic_esp:generic_esp_01"
print("ClientID: "..CLIENTID)
BRPWD  = "***********"

BRUSER = "use-token-auth"

local function publish()
   dofile('sensor.lc')
   m:publish('iot-2/evt/esp8266/fmt/json',payload,1,0, 
            function(conn) print('Payload published') end)
end

m = mqtt.Client(CLIENTID, 120, BRUSER, BRPWD)
c = false

print('MQTT Init')
m:on('offline', function(con) print('mqtt offline'); c = false end)
m:connect(BROKER, BRPORT, 1, function(conn) 
   print('MQTT connected: '..BROKER..':'..BRPORT) 
   c = true 
   publish()
end)

tmr.alarm(1, 1000, 1, function() 
    if not c then
      print('MQTT reconnecting')
      m:close()
      c = false
      m:connect(BROKER, BRPORT, 1, function(conn) print('.. MQTT reconnected: '..BROKER..':'..BRPORT); c = true end)
    end
    if c then
      publish()
    end
 end)

esp8266 只是打印 "MQTT reconnecting" 并且无法连接。 我的代码有问题还是 NodeMCU 1.4 不完全支持 TLS?

我在我们的一个测试台上拍下了您的客户问候语:

0000 16 03 02 00 33 01 00 00 2f 03 02 00 00 00 00 d0 0010 b1 a1 3a 07 1c 1b 3e f2 fc 03 91 d6 18 b5 ae 5d 0020 77 65 37 f5 07 10 45 d1 7e 1a ea 00 00 08 00 2f 0030 00 35 00 05 00 04 01 00

这看起来像 TLS v1。1 客户端问候。通常客户会问候它可以做的 "best" 并向下协商。在这种情况下,IoTF 将简单地关闭连接,因为它仅支持 TLS 1.2。请检查您的设备是否设置为执行 TLS 1.2?