加入星計劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴(kuò)散
  • 作品版權(quán)保護(hù)
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長期合作伙伴
立即加入
  • 正文
    • 1 安裝ArduinoJson庫
    • 2 ArduinoJson庫的使用
    • 3 應(yīng)用實(shí)例
    • 結(jié)束語
  • 推薦器件
  • 相關(guān)推薦
  • 電子產(chǎn)業(yè)圖譜
申請入駐 產(chǎn)業(yè)圖譜

Arduino應(yīng)用開發(fā)——JSON的構(gòu)建與解析

2024/03/07
7340
閱讀需 16 分鐘
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點(diǎn)資訊討論

JSON 全稱“JavaScript Object Notation”,譯為“JavaScript對象簡譜”或“JavaScript對象表示法”,是一種輕量級的、基于文本的、開放的數(shù)據(jù)交換格式。JSON 在Web開發(fā)領(lǐng)域有著舉足輕重的地位,如果您想在Web開發(fā)領(lǐng)域大展身手的話,就必須了解JSON。

盡管JSON的名稱中包含“JavaScript”,但它并不是只能在JavaScript中使用,大多數(shù)編程語言都支持JSON(有些本身就支持,有些可以通過第三方庫得到支持),例如 JavaScript、Java、PHP、Python、C、C++ 等。

嵌入式領(lǐng)域,當(dāng)我們的設(shè)備需要跟服務(wù)器進(jìn)行數(shù)據(jù)交互時往往也會使用JSON格式。因此,本文著重介紹Arduino環(huán)境下如果構(gòu)建和解析JSON格式數(shù)據(jù)。

1 安裝ArduinoJson庫

要想在Arduino平臺構(gòu)建和解析JSON格式數(shù)據(jù)需要借助第三方庫。本文主要講解如何使用ArduinoJson庫來實(shí)現(xiàn)JSON構(gòu)建和解析。
ArduinoJson(全稱:ArduinoJson-C++ JSON Library for IoT)是嵌入式系統(tǒng)中優(yōu)雅和高效的Json庫。它僅使用最基本的API,確保工作時消耗最小的內(nèi)存空間。雖然它的命名中包含“Arduino”,但事實(shí)上并沒有引用Arduino的任何庫文件,因此ArduinoJson可以應(yīng)用在任何的C++項(xiàng)目中。

打開Arduino IDE,點(diǎn)擊 工具 -> 管理庫,在搜索框輸入ArduinoJson,下載安裝即可。
注:不同版本的ArduinoJson庫API的使用是有區(qū)別的,主要分成V5和V6兩個版本,本文測試時使用的是當(dāng)前最新的6.19.4版本。建議用新不用舊,因?yàn)楦驴隙ㄊ峭玫姆较蛉?yōu)化的。

2 ArduinoJson庫的使用

2.1 Json的構(gòu)建

構(gòu)建示例:

StaticJsonDocument<200> jsonBuffer;   //聲明一個JsonDocument對象,長度200

// 添加對象節(jié)點(diǎn)
jsonBuffer["key1"] = 123;          // 整數(shù)
jsonBuffer["key2"] = 123.123;      // 浮點(diǎn)數(shù)
jsonBuffer["key3"] = "string";     // 字符串

// 添加數(shù)組對象
JsonArray array1 = jsonBuffer.createNestedArray("array");// 添加一個 "array" 數(shù)組
array1.add(1);    // 往數(shù)組里面添加值
array1.add(1.2);  // 往數(shù)組里面添加值
array1.add(-10);  // 往數(shù)組里面添加值

// 對象嵌套
JsonObject root = jsonBuffer.createNestedObject("key4"); //添加一個對象節(jié)點(diǎn)
root["key1"] = "hello";

String output;
serializeJson(jsonBuffer, output);  // 序列化JSON數(shù)據(jù)并導(dǎo)出字符串

Serial.println(output);             // 串口打印最后輸出的字符串

構(gòu)建輸出結(jié)果:

{"key1":123,"key2":123.123,"key3":"string","array":[1,1.2,-10],"key4":{"key1":"hello"}}
{
    "key1":123,
    "key2":123.123,
    "key3":"string",
    "array":[1,1.2,-10],
    "key4":{
        "key1":"hello"
    }
}

2.2 Json的解析

解析示例:

StaticJsonDocument<200> jsonBuffer; //聲明一個JsonDocument對象,長度200

// 聲明一個JSON數(shù)據(jù),用作測試
char json[] ="{"str":"welcome","data1":1351824120,"data2":[48.756080,2.302038],"object":{"key1":-254}}";

// 反序列化JSON
DeserializationError error = deserializeJson(jsonBuffer, json);
if (error) 
{
    Serial.print(F("deserializeJson() failed: "));
    Serial.println(error.f_str());
    return;
}

// 解析JSON
const char* str = jsonBuffer["str"];           // 讀取字符串
long data1 = jsonBuffer["data1"];              // 讀取整形數(shù)據(jù)
double latitude = jsonBuffer["data2"][0];      // 讀取數(shù)組
double longitude = jsonBuffer["data2"][1];     // 讀取數(shù)組
int key1 = jsonBuffer["object"]["key1"];       // 讀取嵌套對象

// 輸出結(jié)果:打印解析后的值
Serial.println(str);      
Serial.println(data1);
Serial.println(latitude, 6);
Serial.println(longitude, 6);
Serial.println(key1);

解析輸出結(jié)果:

welcome
1351824120
48.756080
2.302038
-254

3 應(yīng)用實(shí)例

示例代碼:

#include <ArduinoJson.h>
void setup()
{
    // 初始化串口
    Serial.begin(115200);
}
void loop() {
    /* 構(gòu)建JSON */
    StaticJsonDocument<200> jsonBuffer;   //聲明一個JsonDocument對象,長度200
    // 添加對象節(jié)點(diǎn)
    jsonBuffer["key1"] = 123;          // 整數(shù)
    jsonBuffer["key2"] = 123.123;      // 浮點(diǎn)數(shù)
    jsonBuffer["key3"] = "string";     // 字符串
    // 添加數(shù)組對象
    JsonArray array1 = jsonBuffer.createNestedArray("array");// 添加一個 "array" 數(shù)組
    array1.add(1);    // 往數(shù)組里面添加值
    array1.add(1.2);  // 往數(shù)組里面添加值
    array1.add(-10);  // 往數(shù)組里面添加值
    // 對象嵌套
    JsonObject root = jsonBuffer.createNestedObject("key4"); //添加一個對象節(jié)點(diǎn)
    root["key1"] = "hello";
    // 輸出結(jié)果:打印構(gòu)建好的JSON數(shù)據(jù)
    String output;
    serializeJson(jsonBuffer, output);  // 序列化JSON數(shù)據(jù)并導(dǎo)出字符串
    Serial.println(output);             // 串口打印最后輸出的字符串

    /* 構(gòu)建JSON的另外一種方法 */
    DynamicJsonDocument doc(200);       // 聲明對象的另外一種方法,和上面的 StaticJsonDocument<200> jsonBuffer 一樣
    char string[100] = {"{"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}"};  // 聲明一個JSON數(shù)據(jù)
    deserializeJson(doc, string);       
    JsonObject obj = doc.as<JsonObject>(); 
    obj["sensor"] = "fan";          // 修改原來的值 
    obj["add"] = 123;               // 添加新對象 
    // 輸出結(jié)果:打印構(gòu)建好的JSON數(shù)據(jù)
    String output2;
    serializeJson(doc, output2);    // 序列化JSON數(shù)據(jù)并導(dǎo)出字符串
    Serial.println(output2);        // 串口打印最后輸出的字符串
    delay(1000);

    /* 解析JSON */
    StaticJsonDocument<200> jsonBuffer2; //聲明一個JsonDocument對象,長度200
    // 聲明一個JSON數(shù)據(jù),用作測試
    char json[] ="{"str":"welcome","data1":1351824120,"data2":[48.756080,2.302038],"object":{"key1":-254}}";
    // 反序列化JSON
    DeserializationError error = deserializeJson(jsonBuffer2, json);
    if (error) 
    {
        Serial.print(F("deserializeJson() failed: "));
        Serial.println(error.f_str());
        return;
    }
    // 解析JSON
    const char* str = jsonBuffer2["str"];           // 讀取字符串
    long data1 = jsonBuffer2["data1"];              // 讀取整形數(shù)據(jù)
    double latitude = jsonBuffer2["data2"][0];      // 讀取數(shù)組
    double longitude = jsonBuffer2["data2"][1];     // 讀取數(shù)組
    int key1 = jsonBuffer2["object"]["key1"];       // 讀取嵌套對象
    // 輸出結(jié)果:打印解析后的值
    Serial.println(str);      
    Serial.println(data1);
    Serial.println(latitude, 6);
    Serial.println(longitude, 6);
    Serial.println(key1);
    delay(1000);
}

輸出結(jié)果:

{"key1":123,"key2":123.123,"key3":"string","array":[1,1.2,-10],"key4":{"key1":"hello"}}
{"sensor":"fan","time":1351824120,"data":[48.75608,2.302038],"add":123}

welcome
1351824120
48.756080
2.302038
-254

結(jié)束語

好了,關(guān)于如何在Arduino上使用JSON的講解就到這里。本文只是簡單的介紹了最常用的幾個操作,更多的用法可以在官網(wǎng)上查閱。

ArduinoJson API介紹:
https://arduinojson.org/v5/api/
https://arduinojson.org/v6/api/

想了解更多Arduino的內(nèi)容,可以關(guān)注一下博主,后續(xù)我還會繼續(xù)分享更多的經(jīng)驗(yàn)給大家。

esp8266基于Arduino的開發(fā)教程匯總:https://blog.csdn.net/ShenZhen_zixian/article/details/121659482

還有什么問題的話,歡迎在評論區(qū)留言。如果這篇文章能夠幫到你,就…你懂得。

推薦器件

更多器件
器件型號 數(shù)量 器件廠商 器件描述 數(shù)據(jù)手冊 ECAD模型 風(fēng)險等級 參考價格 更多信息
74HC08D,653 1 NXP Semiconductors 74HC(T)08 - Quad 2-input AND gate SOIC 14-Pin

ECAD模型

下載ECAD模型
$0.3 查看
NC7SZ08P5X 1 Rochester Electronics LLC LVC/LCX/Z SERIES, 2-INPUT AND GATE, PDSO5, 1.25 MM, ROHS COMPLIANT, EIAJ, SC-88A, SC-70, 5 PIN
$0.28 查看
ECS-.327-12.5-38-TR 1 ECS International Inc Parallel - Fundamental Quartz Crystal, 0.032768MHz Nom, ROHS COMPLIANT, MINIATURE, PLASTIC, SMD, 4 PIN

ECAD模型

下載ECAD模型
$0.85 查看

相關(guān)推薦

電子產(chǎn)業(yè)圖譜