【问题标题】:mbedtls_net_connect returned -0x52 when connecting to AWS IoT using ESP32 in Arduino IDE在 Arduino IDE 中使用 ESP32 连接到 AWS IoT 时,mbedtls_net_connect 返回 -0x52
【发布时间】:2018-04-12 08:53:07
【问题描述】:

我正在尝试在 Arduino IDE 的帮助下使用我的 ESP32 板上的基本 pubsub 示例连接到 AWS IoT。

作为一个基本示例,它确实连接到 AWS IoT 并发布消息,但是当我为程序提供静态 IP 时,它确实连接到具有指定 IP 地址的 wifi(我还为 MAC 地址分配了一个静态 IP我的路由器中的板),但它无法发布消息并给我以下错误:

正在尝试连接到 SSID:RCB Rocks!!!! 已连接到无线网络

E (37583) aws_iot:失败! mbedtls_net_connect 返回 -0x52

E (37583) AWS_IOT: Error(-23) 连接到 ***********.iot.eu-west-2.amazonaws.com:8883,

正在尝试重新连接

我正在使用以下代码:

#include <AWS_IOT.h>
#include <WiFi.h>
AWS_IOT hornbill;

char WIFI_SSID[]="RCB Rocks!!!!";
char WIFI_PASSWORD[]="********";
char HOST_ADDRESS[]="************.iot.eu-west-2.amazonaws.com";
char CLIENT_ID[]= "1008";
char TOPIC_NAME[]= "smk";
IPAddress ip(192, 168, 0, 20);
IPAddress gateway(192, 168, 0, 1);
IPAddress subnet(255, 255, 255, 0);
int status = WL_IDLE_STATUS;
int tick=0,msgCount=0,msgReceived = 0;
char payload[512];
char rcvdPayload[512];

void mySubCallBackHandler (char *topicName, int payloadLen, char *payLoad) {
  strncpy(rcvdPayload,payLoad,payloadLen);
  rcvdPayload[payloadLen] = 0;
  msgReceived = 1;
}

void setup() {
  Serial.begin(115200);
  delay(2000);
  while (status != WL_CONNECTED) {
    Serial.print("Attempting to connect to SSID: ");
    Serial.println(WIFI_SSID);
    WiFi.config(ip,gateway,subnet);
    WiFi.mode(WIFI_STA);
    // Connect to WPA/WPA2 network. Change this line if using open or WEP network:
    status = WiFi.begin(WIFI_SSID, WIFI_PASSWORD);
    // wait 5 seconds for connection:
    delay(5000);
  }

  Serial.println("Connected to wifi");
  if(hornbill.connect(HOST_ADDRESS,CLIENT_ID)== 0) {
    Serial.println("Connected to AWS");
    delay(1000);
    if(0==hornbill.subscribe(TOPIC_NAME,mySubCallBackHandler)) {
      Serial.println("Subscribe Successfull");
    } else {
      Serial.println("Subscribe Failed, Check the Thing Name and Certificates");
      while(1);
    }
  } else {
    Serial.println("AWS connection failed, Check the HOST Address");
    while(1);
  }
  delay(2000);
}

void loop() {
  if(msgReceived == 1) {
    msgReceived = 0;
    Serial.print("Received Message:");
    Serial.println(rcvdPayload);
  }
  if(tick >= 5) {
    // publish to topic every 5seconds
    tick=0;
    sprintf(payload,"Hello from hornbill ESP32 : %d",msgCount++);
    if(hornbill.publish(TOPIC_NAME,payload) == 0) {
      Serial.print("Publish Message:");
      Serial.println(payload);
    } else {
      Serial.println("Publish failed");
    }
  }
  vTaskDelay(1000 / portTICK_RATE_MS);
  tick++;
}

我找到了适用于 Arduino ESP32 的 AWS IoT SDK here,并按照this website 中的说明进行操作。

【问题讨论】:

    标签: arduino aws-iot mbedtls esp32


    【解决方案1】:

    正在尝试连接到 SSID:RCB Rocks!!!!连接到wifi

    因此您的主板能够获得网络连接。

    E (37583) aws_iot:失败! mbedtls_net_connect 返回 -0x52

    这个错误意味着

    NET - 获取给定主机名的 IP 地址失败

    主机名错误或您的 DNS 设置有问题。鉴于您的程序在您不使用静态 IP 地址时可以正常工作,问题一定出在板上的 DNS 设置上。当开发板从 DHCP 接收到动态 IP 地址时,DHCP 服务器也会向其发送 DNS 设置。如果您使用静态 IP 地址而不是 DHCP,则还需要静态设置 DNS 服务器。

    【讨论】:

      【解决方案2】:

      您可能想尝试查看 ESP 板是否甚至可以使用该静态 IP 连接到互联网。您可以尝试运行此草图。 https://learn.sparkfun.com/tutorials/esp32-thing-hookup-guide#arduino-example-wifi

      如果我从 chrome 连接到无线,我的板上也遇到了同样的问题,并且得到了 DNS_PROBE_FINISHED_NO_INTERNET。更改为不同的网络解决了这个问题。

      【讨论】:

        【解决方案3】:

        我知道这已经过时了,但是将 Wifi.begin() 移到 for 循环之外对我来说是诀窍:

        WiFi.config(ip,gateway,subnet);
        WiFi.mode(WIFI_STA);
        
        Serial.print("Attempting to connect to SSID: ");
        Serial.println(WIFI_SSID);
        
        // Connect to WPA/WPA2 network. Change this line if using open or WEP network:
        WiFi.begin(WIFI_SSID, WIFI_PASSWORD);
        
        while (WiFi.status() != WL_CONNECTED) {
          Serial.print(".");
          delay(500);
        }
        
        Serial.print("connected.");
        

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 2022-07-29
          • 2021-05-03
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2021-11-01
          • 1970-01-01
          相关资源
          最近更新 更多