Я пытаюсь подключиться к AWS с помощью библиотеки paho MQTT C. Я правильно настроил свою вещь AWS и сертификаты. Я проверил это, опубликовав с использованием инструментов mosquitto и MQTTFx.
Я попытался сопоставить URL-адрес подключения, файлы сертификатов и ключи с параметрами, необходимыми для MQTTClient.ssl., Но вызов подключения продолжает сбой.
Я не могу опубликовать весь код здесь, поэтому я просто отправлю соответствующие биты.
#define ADDRESS "ssl://xxxxxxxxxxxxxxxx-2.amazonaws.com:8883"
#define CLIENTID "testclient"
#define TOPIC_REQ "req/16000393" //this is the topic I'm subscribing to at AWS side (publishing from client laptop)
...
#define CRT_FILE "./certificate.pem.crt"
#define KEY_FILE "./private.pem.key"
#define CA_FILE "./rootCA.pem"
...
int main(int argc, char* argv[])
{
MQTTClient client;
MQTTClient_connectOptions conn_opts = MQTTClient_connectOptions_initializer;
MQTTClient_message pubmsg = MQTTClient_message_initializer;
MQTTClient_deliveryToken token;
MQTTClient_SSLOptions sslopts = MQTTClient_SSLOptions_initializer;
int rc;
int ch;
conn_opts.ssl = &sslopts;
conn_opts.ssl->trustStore = CRT_FILE;
conn_opts.ssl->keyStore = CA_FILE;
conn_opts.ssl->privateKey = KEY_FILE;
conn_opts.ssl->verify = 1;
MQTTClient_create(&client, ADDRESS, CLIENTID,
MQTTCLIENT_PERSISTENCE_NONE, NULL);
conn_opts.keepAliveInterval = 20;
conn_opts.cleansession = 1;
MQTTClient_setCallbacks(client, NULL, connlost, msgarrvd, delivered);
if ((rc = MQTTClient_connect(client, &conn_opts)) != MQTTCLIENT_SUCCESS)
{
printf("Failed to connect, return code %d\n", rc);
exit(EXIT_FAILURE);
}
...
Соединение продолжает сбой. Пожалуйста, помогите! У меня нет идей.