对传入的MQTT消息无反应

时间:2020-05-23 11:45:52

标签: arduino mqtt publish-subscribe

我有一个带按钮和一些LED的wemos d1 mini的简单设置。它可以发送和接收MQTT消息,并应对此采取行动。

我希望它在按下按钮时发送“ 11”,并在接收到特定消息(在这种情况下为“ 21”)时点亮LED。

一切似乎都正常,该消息正在发出,并且报告该消息进入时它“看到”“ 21”。但是随后它跳过了IF语句,在这里我比较传入的带字符串的消息。它们的打印结果相同,但是IF比较似乎表明它们并非相同。这是在回调循环中完成的。

有人可以指出我出问题的地方吗?


long lastMsg = 0;
char msg[50];
int value = 0;
char* msgIN;
String msgIN_trigger;
char* msgOUT;
String boxID = "1";
int boxID_len = boxID.length() + 1;
String clientID = "rememberbox " + boxID;
int clientID_len = clientID.length() + 1;

void callback(char* topic, byte* payload, unsigned int length) {
  Serial.print("Message arrived: [");
  Serial.print(topic);
  Serial.print("] ");
  String msgIN = "";
  msgIN += (char *)payload;
  String msgString = msgIN;
  Serial.print(msgIN.substring(0,2));
  Serial.println("/");


    if (msgString == msgIN_trigger) {
      Serial.println("message is for me!");
      Serial.println("wake up MP3 player");
      myMP3.wakeUp();
      Serial.println("play track 5");
      myMP3.play(5);
      Serial.println("confetti!!!");
      confetti();
      Serial.println("and fade to black");
      for (int i = 0; i < NUM_LEDS; i++) {
        leds[i] = CRGB::Black;
      }
      FastLED.show();
      delay(7500);
      myMP3.sleep();
      message_out = false;
      Serial.println("message_out = false");
      Serial.println("");
    }

    Serial.println("nothing intended for me");
    Serial.print("only reacting to message: ");
    Serial.print(msgIN_trigger);
    Serial.println("/");
    Serial.println("");
}

1 个答案:

答案 0 :(得分:1)

您正在使用操作数尝试比较两个String ...这可能会导致不稳定的操作。试试这个

if (strcmp(msgString, msgIN_trigger) == 0) {
   ...
}

这是我使用的,而且似乎工作正常。