MQTT 客户端未订阅给定主题(或回调未按预期工作)

问题描述 投票:0回答:2

我快要疯了,试图猜测为什么我的 Arduino Nano33 无法接收 mqtt 消息。或者它可能收到它们,但回调函数没有按我的预期工作(因为回调是我查看是否收到消息的唯一方法)。

我可以毫无问题地发布消息。关于我的代码中可能出现问题的任何线索吗? (我对 C++ 的经验为零,所以这可能是一些愚蠢的错误)。

我正在复制整个代码,以防问题出在其他地方,但我想要查看的关键函数是

callback
setup

#include <WiFiNINA.h> 
#include <PubSubClient.h>
#include <Arduino_LSM6DS3.h>
#include "credentials.h"

const char* ssid = SSID_WIFI;
const char* password = PW_WIFI;
const char* mqttServer = MQTT_SERVER;
const int mqttPort = MQTT_PORT;
const char* mqttUsername = MQTT_USRNM;
const char* mqttPassword = MQTT_PW;
char pubTopic[] = "sensors/imu1/values";
char subTopic[] = "sensors/imu1/mode";

WiFiSSLClient wifiClient; //SSL
PubSubClient client(wifiClient);
void setup_wifi()

//Connect to wifi network 
{
  delay(10);  
  Serial.println();
  Serial.print("Connecting to ");
  Serial.println(ssid);
  WiFi.begin(ssid, password);
  while (WiFi.status() != WL_CONNECTED) 
  {
    delay(500);
    Serial.print(".");
  }
  randomSeed(micros());
  Serial.println("");
  Serial.println("WiFi connected");
  Serial.println("IP address: ");
  Serial.println(WiFi.localIP());
}

void callback(char* topic, byte* payload, unsigned int length) {
  //char* payload_chr;
  Serial.print("Message arrived [");  
  Serial.print(topic);  
  Serial.print("] ");
  for (int i=0;i<length;i++) {
    //payload_chr[i] = (char)payload[i];
    Serial.print((char)payload[i]);
  }
  Serial.println();
  //String message = payload_chr;
  //Serial.print(message);
}

void reconnect() 
{
  // Loop until we're reconnected
  while (!client.connected()) 
  {
    Serial.print("Attempting MQTT connection...");
    String clientId = "Nano33-";
    clientId += String(random(0xffff), HEX);
    // Attempt to connect
    if (client.connect(clientId.c_str(), mqttUsername, mqttPassword)) 
    {
      Serial.println("connected");
      // ... and resubscribe
      client.subscribe(subTopic);
    } else 
    {
      Serial.print("failed, rc=");
      Serial.print(client.state());
      Serial.println(" try again in 5 seconds");
      // Wait 5 seconds before retrying
      delay(5000);
    }
  }
}

void setup() 
{   
  Serial.begin(9600);
  setup_wifi();
  client.setServer(mqttServer, mqttPort);
  client.setCallback(callback);  
  if (!IMU.begin()) {
    Serial.println("Failed to initialize IMU!");
    while (1);
  }
  Serial.println("IMU initialized!");  
}

void publish_imu_values(float x_acc, float y_acc, float z_acc, 
                        float x_gyr, float y_gyr, float z_gyr){
  //Publish imu readings in InfluxDB Line Protocol format
  String temp_str;
  char mensaje[100];
  temp_str  = "imu x_acc=";
  temp_str += String(x_acc);
  temp_str += ",y_acc=";
  temp_str += String(y_acc);
  temp_str += ",z_acc=";
  temp_str += String(z_acc);
  temp_str += ",x_gyr=";
  temp_str += String(x_gyr);
  temp_str += ",y_gyr=";
  temp_str += String(y_gyr);
  temp_str += ",z_gyr=";
  temp_str += String(z_gyr);        
  temp_str.toCharArray(mensaje, temp_str.length() + 1);  
  client.publish(pubTopic, mensaje);      
}

void loop() 
{
  if (!client.connected()) 
  {
    reconnect();
  }
  float x_acc, y_acc, z_acc;
  float x_gyr, y_gyr, z_gyr;  
  if (IMU.accelerationAvailable() && IMU.gyroscopeAvailable()) {
    IMU.readAcceleration(x_acc, y_acc, z_acc);
    IMU.readGyroscope(x_gyr, y_gyr, z_gyr);
    publish_imu_values(x_acc, y_acc, z_acc, x_gyr, y_gyr, z_gyr);    
  }  
  delay(1000);
}
c++ arduino mqtt
2个回答
3
投票

您需要在

client.loop();
主函数中添加
loop()
行。如果没有该行,您的 MQTT 代码将永远不会被执行。


0
投票

你得到答案了吗?如果是这样,请提供解决方案,因为我面临着类似的问题。即使数据发布成功,我的回调函数也没有执行。

© www.soinside.com 2019 - 2024. All rights reserved.