MQTT через SSL с PAHO C - PullRequest
       35

MQTT через SSL с PAHO C

0 голосов
/ 30 марта 2020

Я пытаюсь понять, как paho работает с SSL. Я протестировал простой паб (без SSL), используя mosquitto в качестве брокера (по умолчанию mosquitto.conf), и все работает хорошо. Теперь я изменил код ниже (используя определение ADDRESS вместо ADDRESSTEST) для тестирования SSL. Я использовал сертифицированное в разделе " test " Paho.

#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <MQTTClient.h>


#define ADDRESS     "ssl://localhost:18885"
#define ADDRESSTEST     "tcp://localhost:1883"
#define CLIENTID    "ExampleClientPub"
#define TOPIC       "MQTTExamples"
#define PAYLOAD     "Hello World!"
#define QOS         1
#define TIMEOUT     10000L


int main() {

MQTTClient client;

MQTTClient_connectOptions conn_opts = MQTTClient_connectOptions_initializer;
MQTTClient_SSLOptions ssl_opts = MQTTClient_SSLOptions_initializer;;

MQTTClient_message pubmsg = MQTTClient_message_initializer;
MQTTClient_deliveryToken token;
int rc;

MQTTClient_create(&client, ADDRESS, CLIENTID,
    MQTTCLIENT_PERSISTENCE_DEFAULT, NULL);

conn_opts.keepAliveInterval = 20;
conn_opts.cleansession = 1;

conn_opts.ssl = &ssl_opts;
conn_opts.ssl->trustStore = "../../validpath/test-root-ca.crt";
conn_opts.ssl->keyStore = "../../validpath/client.pem";

conn_opts.serverURIcount = 0;
conn_opts.serverURIs = NULL;

if ((rc = MQTTClient_connect(client, &conn_opts)) != MQTTCLIENT_SUCCESS)
{
    printf("Failed to connect, return code %d\n", rc);
    exit(EXIT_FAILURE);
}

pubmsg.payload = PAYLOAD;
pubmsg.payloadlen = (int)strlen(PAYLOAD);
pubmsg.qos = QOS;
pubmsg.retained = 0;


MQTTClient_publishMessage(client, TOPIC, &pubmsg, &token);
printf("Waiting for up to %d seconds for publication of %s\n"
        "on topic %s for client with ClientID: %s\n",
        (int)(TIMEOUT/1000), PAYLOAD, TOPIC, CLIENTID);
rc = MQTTClient_waitForCompletion(client, token, TIMEOUT);
printf("Message with delivery token %d delivered\n", token);
MQTTClient_disconnect(client, 10000);
MQTTClient_destroy(&client);

return 0;
}

Проблема в том, что когда я запускаю программное обеспечение с этой конфигурацией, MQTTClient_connect возвращает мне код MQTTCLIENT_WRONG_MQTT_VERSION . Mosquitto работает на localhost, и я изменил mosquitto.conf следующим образом:

# server authentication - no client authentication
listener 18885
cafile validpath/all-ca.crt
certfile validpath/server.crt
keyfile validpath/server.key
require_certificate false
#tls_version tlsv1

1 Ответ

0 голосов
/ 31 марта 2020

Эта проблема возникает при компиляции с -lpaho-mqtt3 c вместо -lpaho-mqtt3cs (который включает SSL). Теперь это работает правильно!

...