如何解决ESP32 HTTPS POST JSON 到 AWS
我正在尝试通过 HTTPS 发布将一些数据发布到 AWS,但似乎无法到达那里。
设置主机到服务器地址和路径到/prod 该方法尚不需要身份验证。 当我连接时它只是被冻结并且没有响应, 尽管说它已连接。
也尽量不使用path,设置主机的完整路径
不太确定为什么会这样,这是我尝试过的两种方法:
void postToAmazonSecure(String jsonToSend){
WiFiClientSecure client;
Serial.print("connecting to : '");
Serial.print(emonDataAPI);
Serial.println("'");
Serial.println(emonDataAPI.c_str());
client.connect(emonDataAPI.c_str(),443);
Serial.print("requesting URL: '");
Serial.print(emonDataAPI);
Serial.println("'");
String requestString = String("POST ") + emonDataAPIPath + " HTTP/1.1\r\n" +
"Host: " + emonDataAPI + "\r\n" +
"Connection: close\r\n" +
"Content-Type: application/json" +
//"Authorization: Bearer " + authorization_code + "\r\n" +
"Content-Length: " + jsonToSend.length() + "\r\n" +
"\r\n" +
jsonToSend + "\r\n";
Serial.println(requestString);
client.print(requestString);
Serial.println("request sent");
unsigned long timeout = millis();
while (client.available() == 0) {
if (millis() - timeout > 5000) {
Serial.println(">>> Client Timeout !");
client.stop();
return;
}
}
}
void postSecure(String jsonToSend){
WiFiClientSecure client;
Serial.print("connect: "); Serial.println(emonDataAPI);
while ( ! client.connect(emonDataAPI.c_str(),443)) {
Serial.print(".");
}
Serial.println("Connected");
String msg = "POST " + emonDataAPIPath + " HTTP/1.1\r\n"
"Host: " + emonDataAPI + "\r\n"
"Content-Type: application/json\r\n"
"Content-Length: " + jsonToSend.length() + "\r\n"
"\r\n" + jsonToSend;
client.print(msg);
Serial.print(msg);
Serial.print("\n*** Request sent,receiving response...");
while (!!!client.available()) {
delay(50);
Serial.print(".");
}
Serial.println();
Serial.println("Got response");
while(client.available()){
Serial.write(client.read());
}
Serial.println(); Serial.println("closing connection");
client.stop();
}
解决方法
您忘记了 \r\n
行末尾的 Content-Type
。应该是:
"Content-Type: application/json\r\n" +
您也没有向 WiFiClientSecure
提供指纹或证书,以便它可以验证您要连接的服务器。这也会阻止您的代码工作。您应该为保护您尝试连接的端点的证书链提供根证书:
const char* test_root_ca= \
"-----BEGIN CERTIFICATE-----\n" \
...
"-----END CERTIFICATE-----\n";
...
client.setCACert(test_root_ca);
client.connect(emonDataAPI.c_str(),443);
您可以在 WiFiClientSecure library examples 中找到更完整的示例。
您还可以查看 README for WiFiClientSecure 了解更多详细信息。
如果没有根证书,WiFiClientSecure
将无法验证您正在连接的服务器的身份。 Windows、Linux 和 macOS 系统都会自动处理;这样做的开销超出了 ESP32 的操作环境的承受能力。
您可以告诉 WiFiClientSecure
不要费心验证服务器,但这样做也是在说“我并不真正关心安全性”。您可能会这样做以进行调试,但将其保留在实际使用的代码中是一种极其糟糕和危险的做法。
client.setInsecure();
client.connect(emonDataAPI.c_str(),443);
这些类型的错误是为什么您几乎总是使用像 HTTPClient
这样的库比滚动您自己的 HTTP(S) 实现更好的重要原因。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。