1

我已经对我的 ESP8266 进行了编程并订阅了一个主题以继续收听消息。这是我向 IBM IoT 节点注入消息的图形视图。

在此处输入图像描述

这是我的注入视图设置

在此处输入图像描述

这是我对 IBM IoT 节点的设置。

在此处输入图像描述

这是我在串行监视器上的日志,它已连接并订阅了 cmd 频道

在此处输入图像描述

到目前为止一切顺利,当我尝试向我的 IBM IoT 节点注入消息时,它没有发布消息,因为它没有到达串行监视器并且没有登录调试视图。在这里你可以看到

在此处输入图像描述

这是源代码:

#include <ESP8266WiFi.h>
#include <PubSubClient.h> // https://github.com/knolleary/pubsubclient/releases/tag/v2.3

const char* ssid = "shiv";
const char* password = "manmohan@12345";

#define ORG "2kafk4"
#define DEVICE_TYPE "ESP8266"
#define DEVICE_ID "5CCF7FEED6F0"
#define TOKEN "opKF7v3@8jRM*mGkb_"

char server[] = ORG ".messaging.internetofthings.ibmcloud.com";
char topic[] = "iot-2/cmd/test/fmt/String";
char authMethod[] = "use-token-auth";
char token[] = TOKEN;
char clientId[] = "d:" ORG ":" DEVICE_TYPE ":" DEVICE_ID;

WiFiClient wifiClient;

void callback(char* topic, byte* payload, unsigned int payloadLength) {
  Serial.print("callback invoked for topic: "); Serial.println(topic);

  for (int i = 0; i < payloadLength; i++) {
    Serial.print((char)payload[i]);
  }
}
PubSubClient client(server, 1883, callback, wifiClient);

void setup() {
  Serial.begin(115200);
  Serial.println();
  wifiConnect();
  mqttConnect();
}

void loop() {
  if (!client.loop()) {
    mqttConnect();
  }
}

void wifiConnect() {
  Serial.print("Connecting to "); Serial.print(ssid);
  WiFi.begin(ssid, password);
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }
  Serial.print("nWiFi connected, IP address: "); Serial.println(WiFi.localIP());
}

void mqttConnect() {
  if (!client.connected()) {
    Serial.print("Reconnecting MQTT client to "); Serial.println(server);
    while (!client.connect(clientId, authMethod, token)) {
      Serial.print(".");
      delay(500);
    }
    initManagedDevice();
    Serial.println();
  }
}

void initManagedDevice() {
  if (client.subscribe(topic)) {
    Serial.println("subscribe to cmd OK");
  } else {
    Serial.println("subscribe to cmd FAILED");
  }
}

我尝试使用cf命令检查云代工日志,这里是https://pastebin.com/dfMaS1Gd

谁能提示我我做错了什么?提前致谢。

4

1 回答 1

1

确认在您的节点配置中正确指定了设备类型。目前,屏幕截图显示 0.16.2 似乎与您注册的设备类型以及您的代码中指定的内容不匹配。

于 2017-06-01T14:06:55.323 回答