吴忠躺衫网络科技有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

paho-mqtt模塊實戰

科技綠洲 ? 來源:TinyZ ? 作者:TinyZ ? 2023-09-20 11:33 ? 次閱讀

MQTT(Message Queuing Telemetry Transport)是一種輕量級的消息傳輸協議,它被設計用于低帶寬和不穩定網絡環境下的物聯網設備通信。Rust是一種安全、并發和高效的編程語言,它在系統編程和網絡編程方面有著很好的表現。在本教程中,我們將介紹如何使用Rust語言和paho-mqtt模塊實現MQTT協議的應用。

前面寫過3篇介紹 rumqttc 的教程,本篇開始使用 paho-mqtt 模塊是c庫的封裝, 支持v5協議,qos 2等更復雜的特性。

環境準備

我們需要先安裝好相關的開發環境。在Cargo.toml中添加依賴:

paho-mqtt = "0.12.1"

連接MQTT服務器

在使用MQTT協議之前,我們需要先連接到MQTT服務器。以下是連接MQTT服務器的示例代碼:

extern crate paho_mqtt as mqtt;

fn main() {
    let host = "tcp://localhost:1883";
    let cli = mqtt::Client::new(host).unwrap();
    let conn_opts = mqtt::ConnectOptionsBuilder::new()
        .keep_alive_interval(std::time::Duration::from_secs(20))
        .clean_session(false)
        .finalize();
    let response = cli.connect(conn_opts).unwrap();
    println!("Connected to MQTT server: {:?}", response);
}

在上面的示例代碼中,我們首先創建了一個MQTT客戶端對象,并指定了MQTT服務器的地址。然后,我們創建了一個連接選項對象,并設置了心跳間隔和會話清除標志。最后,我們使用連接選項對象連接到MQTT服務器,并打印連接響應信息

發布MQTT消息

在連接到MQTT服務器之后,我們可以使用MQTT客戶端對象來發布消息。以下是發布MQTT消息的示例代碼:

extern crate paho_mqtt as mqtt;

fn main() {
    let host = "tcp://localhost:1883";
    let cli = mqtt::Client::new(host).unwrap();
    let conn_opts = mqtt::ConnectOptionsBuilder::new()
        .keep_alive_interval(std::time::Duration::from_secs(20))
        .clean_session(false)
        .finalize();
    let response = cli.connect(conn_opts).unwrap();
    println!("Connected to MQTT server: {:?}", response);

    let topic = "test/topic";
    let payload = "Hello, MQTT!";
    let message = mqtt::MessageBuilder::new()
        .topic(topic)
        .payload(payload)
        .qos(mqtt::QOS_1)
        .finalize();
    let response = cli.publish(message).unwrap();
    println!("Published MQTT message: {:?}", response);
}

在上面的示例代碼中,我們首先連接到MQTT服務器,然后創建了一個MQTT消息對象,并設置了消息主題、消息負載和消息服務質量等級。最后,我們使用MQTT客戶端對象來發布消息,并打印發布響應信息。

訂閱MQTT主題

在使用MQTT協議之前,我們需要先訂閱MQTT主題。以下是訂閱MQTT主題的示例代碼:

extern crate paho_mqtt as mqtt;

fn main() {
    let host = "tcp://localhost:1883";
    let cli = mqtt::Client::new(host).unwrap();
    let conn_opts = mqtt::ConnectOptionsBuilder::new()
        .keep_alive_interval(std::time::Duration::from_secs(20))
        .clean_session(false)
        .finalize();
    let response = cli.connect(conn_opts).unwrap();
    println!("Connected to MQTT server: {:?}", response);

    let topic = "test/topic";
    let qos = mqtt::QOS_1;
    let response = cli.subscribe(topic, qos).unwrap();
    println!("Subscribed to MQTT topic: {:?}", response);
}

在上面的示例代碼中,我們首先連接到MQTT服務器,然后創建了一個MQTT訂閱對象,并設置了訂閱主題和服務質量等級。最后,我們使用MQTT客戶端對象來訂閱主題,并打印訂閱響應信息。

同時發布和訂閱MQTT消息

在使用MQTT協議時,我們通常需要同時發布和訂閱MQTT消息。以下是同時發布和訂閱MQTT消息的示例代碼:

extern crate paho_mqtt as mqtt;

fn main() {
    let host = "tcp://localhost:1883";
    let cli = mqtt::Client::new(host).unwrap();
    let conn_opts = mqtt::ConnectOptionsBuilder::new()
        .keep_alive_interval(std::time::Duration::from_secs(20))
        .clean_session(false)
        .finalize();
    let response = cli.connect(conn_opts).unwrap();
    println!("Connected to MQTT server: {:?}", response);

    let topic = "test/topic";
    let qos = mqtt::QOS_1;
    let response = cli.subscribe(topic, qos).unwrap();
    println!("Subscribed to MQTT topic: {:?}", response);

    let payload = "Hello, MQTT!";
    let message = mqtt::MessageBuilder::new()
        .topic(topic)
        .payload(payload)
        .qos(mqtt::QOS_1)
        .finalize();
    let response = cli.publish(message).unwrap();
    println!("Published MQTT message: {:?}", response);

    for message in cli.start_consuming() {
        println!("Received MQTT message: {:?}", message);
    }
}

在上面的示例代碼中,我們首先連接到MQTT服務器,然后創建了一個MQTT訂閱對象,并設置了訂閱主題和服務質量等級。接著,我們創建了一個MQTT消息對象,并使用MQTT客戶端對象來發布消息。最后,我們使用MQTT客戶端對象來接收消息,并打印接收到的消息。

斷開MQTT服務器連接

在使用MQTT協議之后,我們需要斷開與MQTT服務器的連接。以下是斷開MQTT服務器連接的示例代碼:

extern crate paho_mqtt as mqtt;

fn main() {
    let host = "tcp://localhost:1883";
    let cli = mqtt::Client::new(host).unwrap();
    let conn_opts = mqtt::ConnectOptionsBuilder::new()
        .keep_alive_interval(std::time::Duration::from_secs(20))
        .clean_session(false)
        .finalize();
    let response = cli.connect(conn_opts).unwrap();
    println!("Connected to MQTT server: {:?}", response);

    cli.disconnect(None).unwrap();
    println!("Disconnected from MQTT server.");
}

在上面的示例代碼中,我們首先連接到MQTT服務器,然后使用MQTT客戶端對象來斷開與MQTT服務器的連接,并打印斷開連接信息。

進階使用

在本節中,我們將介紹如何使用Rust語言和paho-mqtt模塊實現MQTT協議的進階應用。我們將提供2個示例,分別是:

    1. 使用SSL/TLS連接MQTT服務器
    1. 使用認證機制連接MQTT服務器

使用SSL/TLS連接MQTT服務器

在使用MQTT協議時,我們通常需要使用SSL/TLS協議來保證通信安全。以下是使用SSL/TLS連接MQTT服務器的示例代碼:

extern crate paho_mqtt as mqtt;
extern crate rustls;

use std::fs::File;
use std::io::BufReader;
use std::sync::Arc;

fn main() {
    let host = "ssl://localhost:8883";
    let cli = mqtt::Client::new(host).unwrap();

    let mut config = rustls::ClientConfig::new();
    let cert_file = &mut BufReader::new(File::open("cert.pem").unwrap());
    config.root_store.add_pem_file(cert_file).unwrap();
    let tls = Arc::new(rustls::ClientSession::new(&Arc::new(config), host));

    let conn_opts = mqtt::ConnectOptionsBuilder::new()
        .keep_alive_interval(std::time::Duration::from_secs(20))
        .ssl_options(mqtt::SslOptionsBuilder::new()
            .ssl_version(mqtt::SslVersion::TlsV1_2)
            .server_name_indication(host)
            .build(tls))
        .clean_session(false)
        .finalize();
    let response = cli.connect(conn_opts).unwrap();
    println!("Connected to MQTT server: {:?}", response);
}

在上面的示例代碼中,我們首先創建了一個MQTT客戶端對象,并指定了使用SSL/TLS協議連接MQTT服務器的地址。然后,我們創建了一個SSL/TLS配置對象,并從PEM文件中加載證書。接著,我們創建了一個SSL/TLS會話對象,并使用SSL/TLS配置對象和MQTT服務器地址來初始化會話對象。最后,我們創建了一個連接選項對象,并設置了心跳間隔、SSL/TLS選項和會話清除標志。我們使用連接選項對象連接到MQTT服務器,并打印連接響應信息。

使用認證機制連接MQTT服務器

在使用MQTT協議時,我們通常需要使用認證機制來保證通信安全。以下是使用認證機制連接MQTT服務器的示例代碼:

extern crate paho_mqtt as mqtt;

fn main() {
    let host = "tcp://localhost:1883";
    let cli = mqtt::Client::new(host).unwrap();

    let username = "user";
    let password = "password";
    let conn_opts = mqtt::ConnectOptionsBuilder::new()
        .keep_alive_interval(std::time::Duration::from_secs(20))
        .user_name(username)
        .password(password)
        .clean_session(false)
        .finalize();
    let response = cli.connect(conn_opts).unwrap();
    println!("Connected to MQTT server: {:?}", response);
}

在上面的示例代碼中,我們首先創建了一個MQTT客戶端對象,并指定了MQTT服務器的地址。然后,我們創建了一個連接選項對象,并設置了心跳間隔、用戶名、密碼和會話清除標志。我們使用連接選項對象連接到MQTT服務器,并打印連接響應信息。

總結

在本教程中,我們介紹了如何使用Rust語言和paho-mqtt模塊實現MQTT協議的應用。我們提供了幾個基礎應用的示例代碼,包括連接MQTT服務器、發布MQTT消息、訂閱MQTT主題、同時發布和訂閱MQTT消息和斷開MQTT服務器連接。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 模塊
    +關注

    關注

    7

    文章

    2731

    瀏覽量

    47741
  • 網絡
    +關注

    關注

    14

    文章

    7599

    瀏覽量

    89241
  • 傳輸協議
    +關注

    關注

    0

    文章

    78

    瀏覽量

    11492
  • MQTT
    +關注

    關注

    5

    文章

    653

    瀏覽量

    22689
  • rust語言
    +關注

    關注

    0

    文章

    57

    瀏覽量

    3028
收藏 人收藏

    評論

    相關推薦

    如何使用Rust語言和paho-mqtt模塊實現MQTT協議

    MQTT是一種輕量級的消息傳輸協議,它被廣泛應用于物聯網和機器對機器通信領域。Rust是一種安全、高效、并發的編程語言,它的生態系統也在不斷壯大。本教程將介紹如何使用Rust語言和paho-mqtt
    的頭像 發表于 09-19 14:41 ?2034次閱讀

    如何在鴻蒙系統中移植 Paho-MQTT 實現MQTT協議

    3方軟件包 paho mqtt去實現MQTT協議功能,最后會給出測試驗證。為后續的物聯網項目打好基礎。友情預告,本節內容較多,源碼也貼出來了,大家最好先看一遍,然后再操作一次。相關源碼已經打包上傳,順便上傳了一個測試OK的固件,
    發表于 10-23 22:57

    【HarmonyOS HiSpark Wi-Fi IoT套件】如何在鴻蒙系統中移植 Paho-MQTT 實現MQTT協議

    一款專為IoT應用場景打造的芯片。本節主要講如何在鴻蒙系統中通過移植第3方軟件包 paho mqtt去實現MQTT協議功能,最后會給出測試驗證。為后續的物聯網項目打好基礎。友情預告,本節內容較多,源碼
    發表于 11-03 17:41

    【直播預熱】Harmony MQTT/CoAP應用指南——火熱報名中

    分析鴻蒙MQTT/CoAP應用1) 鴻蒙MQTT應用指南2) 鴻蒙CoAP應用指南 直播講解知識點:1. MQTT1)MQTT協議和相關開源項目簡介1)移植
    發表于 12-09 17:18

    Harmony MQTT/CoAP應用指南 【直播答疑】:參與直播的小伙伴們,如果您有任何疑問,可在我們電子發燒友論壇發帖提問

    請注意,請使用固定的發帖標題格式,如:【直播提問-許思維老師12/15】如何移植paho-mqtt到鴻蒙?,以便許老師和潤和技術團隊能第一時間發現您的帖子,予以回復哦。
    發表于 12-16 13:49

    如何使用paho-mqtt框架實現溫濕度數據的實時顯示?

    如何使用paho-mqtt實框架現溫濕度數據的實時顯示?
    發表于 10-08 09:12

    基于Eclipse paho-mqtt源碼包的MQTT客戶端設計(上)

    MQTT 軟件包介紹Paho MQTT 是 Eclipse 實現的 MQTT 協議的客戶端,本軟件包是在 Eclipse paho-mqtt
    發表于 08-04 16:28

    基于Eclipse paho-mqtt源碼包的MQTT客戶端設計(下)

    packages → IoT - internet of things 中選擇 Paho MQTT 軟件包,操作界面如下圖所示:開啟功能示例,便于測試 MQTT 功能:配置項介紹如下:---
    發表于 08-04 16:33

    新手求助MQTT選擇哪個軟件包比較合適呢?

    大概看了下當前有 umqtt、umqtt 和 paho-mqtt 幾個軟件包,除了貌似 paho 的那個比較拉跨,其他的兩個有什么優劣么?另外,內網環境下面的 MQTT 的傳輸延遲一般是多少(QoS0/1/2)?性能能到多少?(
    發表于 11-17 10:21

    paho-mqtt重連后AT發送會報錯是什么原因?

    如下圖代碼中使用mqtt_stop后再開啟mqtt_start,前幾條數據還能發出去,但是過一會AT發送數據就會出問題,會導致mqtt再次下線重連,使用的RTT版本為4.0.2,mqtt
    發表于 01-10 15:39

    paho在OneNET平臺的應用

    apiKey,為字符串 安裝 sudo pip install paho-mqtt 關于paho的使用參考:https://pypi.python.org/pypi/paho-mqtt/1.3.0 實現功能: 平臺下發的數據,會
    發表于 12-04 18:57 ?2次下載

    在鴻蒙系統中移植Paho-MQTT實現MQTT協議的詳細教程

    系統中通過移植第 3 方軟件包 Paho-MQTT 去實現 MQTT 協議功能,最后會給出測試驗證。為后續的物聯網項目打好基礎。 友情預告,本節內容較多,源碼也貼出來了,大家最好先看一遍,然后再操作一次。 相關源碼已經打包上傳,順便上傳了一個測試 OK 的固件,大家可以直
    的頭像 發表于 10-24 11:05 ?7728次閱讀
    在鴻蒙系統中移植<b class='flag-5'>Paho-MQTT</b>實現<b class='flag-5'>MQTT</b>協議的詳細教程

    【Linux篇】Paho-MQTT-C移植

    【Linux篇】Paho-MQTT-C移植
    的頭像 發表于 05-05 09:05 ?3208次閱讀

    如何在Python中使用MQTT

    本文主要介紹如何在 Python 項目中使用?paho-mqtt?客戶端庫 ,實現客戶端與?MQTT?服務器的連接、訂閱、取消訂閱、收發消息等功能。
    的頭像 發表于 12-22 10:41 ?9967次閱讀
    如何在Python中使用<b class='flag-5'>MQTT</b>

    通過paho-mqtt軟件包入門rt-thread的sal

    在rt_wlan_register_event_handler函數注冊好RT_WLAN_EVT_READY的回調函數paho_mqtt_start,當wifi準備好后調用mq_start啟動mqtt
    的頭像 發表于 08-09 15:37 ?1521次閱讀
    江山百家乐的玩法技巧和规则| 大发888娱乐场客户端| 伟博百家乐官网现金网| 定制百家乐桌子| 百家乐官网小77论坛| 威尼斯人娱乐城海立方| 百家乐游戏奥秘| 电投百家乐官网网站| 黄金城| 公海百家乐的玩法技巧和规则 | 威尼斯人娱乐城| 太阳城代理最新网址| 百家乐游戏资料网| 三公百家乐官网在线哪里可以玩| 罗定市| 太阳城娱乐城去大丰收娱乐| 国美百家乐的玩法技巧和规则| 百家乐庄闲必赢| 百家乐官网程序开户发| 塘沽区| 威尼斯人娱乐城活动lm0| 百家乐乐翻天| 百家乐娱乐城玩法| 女神百家乐官网的玩法技巧和规则| 百家乐官网长龙怎么预判| 盈乐博| 沙龙百家乐娱乐城| 有百家乐的棋牌游戏| 百家乐揽子打法| 百家乐游戏类型| 百家乐网址多少| 百家乐破解打法| 百家乐下注口诀| 24山向阴阳图| 罗盘的 24卦位| 百家乐投注规则| 属猴人做生意门面的风水| 大连百家乐官网食品| 百家乐官网群shozo| 百家乐单注技巧| 凤凰百家乐娱乐城|