NodeMCU无法通过TLS连接到Bluemix。

我想尝试将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的支持还不完整?

点赞
用户4788178
用户4788178

我已经在我们的一个测试站点中捕获了您的客户端 hello:

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 客户端 hello。通常客户端会使用它能够做到的“最佳”方式来打招呼并向下协商。在这种情况下,IoTF 将简单地关闭连接,因为它只支持 TLS 1.2。请您确认您的设备是否设置为做 TLS 1.2?

2016-01-31 21:14:10