paho_mqtt_c使用加密连接

1 篇文章 0 订阅

在paho-mqtt-c提供的demo中,有paho_c_sub.c和paho_c_pub.c两个demo,使用了加密连接(秘钥、证书,用户名和密码)。可以基于这两个demo来进行调试,查看参数如何设置。

1. 首先确保机器上安装了openssl的库。

2. 在cmakelists.txt中,使能sshl和samples,

SET(PAHO_WITH_SSL TRUE CACHE BOOL "Flag that defines whether to build ssl-enabled binaries too. ")

SET(PAHO_BUILD_SAMPLES TRUE CACHE BOOL "Build sample programs")

3. 在src下的cmakelists.txt中,加入ssl的路径(在这里我电脑是windows环境,所以仅仅设置了Win32下的变量)

SET(OPENSSL_SEARCH_PATH "C:/OpenSSL-Win32"),如下所示:

4. 使用vs编译的工程,创建win32_build,进入目录后,在命令行,

cmake -G "Visual Studio 14" Win32 ..

生成工程如下所示:

同时在src下面有sample文件夹,demo工程就在里面。打开sln文件,编译没有问题后,将启动项设置为paho_c_sub工程。

5. 调试

首先看paho_c_sub的源码,ssh部分如下所示:

可以看出来,如果ssl的参数要被使能,首先opts.connection不为空,并且以ssl://或者wss://开头。而opts.connection通过入参-c被被赋值(在getopts()函数中),如下所示:

所以调试时,在入参中需要填入 -c ssl://xtmqtt.oks.ltd:8883     (注:这里的端口根据具体情况具体分析)

同理,其它参数调试后,设置如下:

--cafile c:\\mqtt_tls\\cacert.pem --cert c:\\mqtt_tls\\client.crt --key c:\\mqtt_tls\\client.key

 

用户名和密码通过-u 和 -P设置。

然后即可连接上broker。

6. 代码

具体到代码侧,如果使能ssl,如下操作即可:

    address = "ssl://xtmqtt.oks.ltd:8883";

    conn_opts=MQTTAsync_connectOptions_initializer;
    MQTTAsync_createOptions create_opts = MQTTAsync_createOptions_initializer;
    clientId = "test";
    MQTTAsync_createWithOptions(&client, address.c_str(), clientId.c_str(), MQTTCLIENT_PERSISTENCE_NONE, NULL, &create_opts);
    MQTTAsync_setCallbacks(client, this, connlost, msgarrvd, NULL);
    conn_opts.keepAliveInterval = 5*60;//change to 3 minutes
    conn_opts.cleansession = 1;
    conn_opts.onSuccess = onConnected;
    conn_opts.onFailure = onConnectFailure;
    conn_opts.context = this;    
    ssl_opts = MQTTAsync_SSLOptions_initializer; 
    ssl_opts.sslVersion=MQTT_SSL_VERSION_DEFAULT;
    ssl_opts.trustStore = "./cacert.pem";   
    ssl_opts.privateKey = "./client.key";
    ssl_opts.keyStore =    "./client.crt";    
    conn_opts.ssl = &ssl_opts;    

    MQTTAsync_connect(client, &conn_opts)

调试窗口内容显示如下:

 

 

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MQTTAsync_rcv是一个函数,它是MQTT C客户端库中的一个函数,用于接收MQTT消息。这个函数的作用是从MQTT服务器接收消息并将其传递给客户端应用程序。它采用异步方式工作,这意味着它可以在后台接收消息而不会阻塞主线程。当接收到消息时,它将调用注册的回调函数来处理消息。 以下是该函数的原型: ``` int MQTTAsync_rcv(MQTTAsync handle, char **topicName, int *topicLen, MQTTAsync_message **message, long timeout); ``` 其中,参数含义如下: - `handle`:MQTT客户端句柄 - `topicName`:指向指针的指针,用于存储消息的主题名称 - `topicLen`:指向int的指针,用于存储主题名称的长度 - `message`:指向指针的指针,用于存储MQTT消息 - `timeout`:超时时间,单位为毫秒 如果成功接收到消息,则返回MQTTASYNC_SUCCESS,否则返回错误代码。 ### 回答2: MQTTAsync_rcv是MQTT客户端库中的一个接收消息的函数。它用于从服务器接收消息并处理消息的回调函数。 当客户端连接MQTT服务器并成功订阅了一个或多个主题后,服务器将会发送相应的消息给客户端。MQTTAsync_rcv函数的作用就是接收并处理这些消息。 使用MQTTAsync_rcv函数,我们可以定义一个回调函数来处理接收到的消息。当服务器发送消息到客户端时,MQTTAsync_rcv函数将被触发,回调函数会被调用。 在回调函数中,我们可以根据消息的主题和内容做出相应的处理。例如,可以解析消息内容,更新应用程序的状态,将消息显示在用户界面上,或者调用其他函数来处理该消息。 需要注意的是,MQTTAsync_rcv函数只有在客户端使用MQTTAsync_subscribe函数成功订阅主题后才能正常接收消息。如果未订阅主题,则无法接收到服务器发送的消息。 通过使用MQTTAsync_rcv函数,我们可以实现基于MQTT协议的即时通信功能,使得客户端能够与服务器进行双向通信,达到实时数据传输的目的。 ### 回答3: MQTTAsync_rcv是一个用于接收MQTT消息的函数。MQTT是一种轻量级的通讯协议,主要用于在物联网领域进行设备间的通讯。MQTTAsync_rcv函数是MQTTAsync库中的一个函数,它允许我们在客户端程序中接收来自MQTT服务器的消息。 使用MQTTAsync_rcv函数,我们可以设置一个回调函数来处理接收到的消息。当有消息到达时,MQTTAsync_rcv函数会调用我们设置的回调函数,并将消息内容作为参数传递给回调函数。我们可以在回调函数中进行对消息的处理和分析,比如打印消息内容、保存消息到数据库等等。 MQTTAsync_rcv函数可以接收不同类型的消息,如发布消息、订阅确认消息等。我们可以根据自己的需求来选择接收哪种类型的消息,并在回调函数中进行相应的处理。 使用MQTTAsync_rcv函数需要先建立与MQTT服务器的连接,并创建一个MQTT订阅。在订阅消息后,我们可以调用MQTTAsync_rcv函数来接收MQTT服务器发送过来的消息。 总之,MQTTAsync_rcv函数是一个功能强大的函数,它使我们能够方便地接收并处理MQTT服务器发送过来的消息,为我们在物联网设备间构建通讯系统提供了很大的便利性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值