在Arduino IDE中使用ESP32连接到AWS IoT时,mbedtls_net_connect返回-0x52

时间:2017-08-01 15:18:06

标签: arduino aws-iot mbedtls esp32

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

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

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

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

E(37583)AWS_IOT:错误(-23)连接到***********。iot.eu-west-2.amazonaws.com:8883, < / p>

尝试重新连接

我使用以下代码:

#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 here找到了这个AWS IoT SDK,我按照this website中的说明进行了操作。

3 个答案:

答案 0 :(得分: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服务器。

答案 1 :(得分:0)

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

我在我的主板上遇到了同样的问题,并且如果我从chrome连接到无线网络,则会收到DNS_PROBE_FINISHED_NO_INTERNET。更改为其他网络修复了该问题。

答案 2 :(得分:0)

我知道这已经过时了,但在for循环之外移动process.env.WHOLESALERSETTINGS对我来说是个窍门:

Wifi.begin()