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庫來實現(xiàn)JSON構(gòu)建和解析。
ArduinoJson(全稱:ArduinoJson-C++ JSON Library for IoT)是嵌入式系統(tǒng)中優(yōu)雅和高效的Json庫。它僅使用最基本的API,確保工作時消耗最小的內(nèi)存空間。雖然它的命名中包含“Arduino”,但事實上并沒有引用Arduino的任何庫文件,因此ArduinoJson可以應(yīng)用在任何的C++項目中。
打開Arduino IDE,點擊 工具 -> 管理庫
,在搜索框輸入ArduinoJson
,下載安裝即可。
注:不同版本的ArduinoJson庫API的使用是有區(qū)別的,主要分成V5和V6兩個版本,本文測試時使用的是當(dāng)前最新的6.19.4版本。建議用新不用舊,因為更新肯定是往好的方向去優(yōu)化的。
2 ArduinoJson庫的使用
2.1 Json的構(gòu)建
構(gòu)建示例:
StaticJsonDocument<200> jsonBuffer; //聲明一個JsonDocument對象,長度200
// 添加對象節(jié)點
jsonBuffer["key1"] = 123; // 整數(shù)
jsonBuffer["key2"] = 123.123; // 浮點數(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é)點
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)用實例
示例代碼:
#include <ArduinoJson.h>
void setup()
{
// 初始化串口
Serial.begin(115200);
}
void loop() {
/* 構(gòu)建JSON */
StaticJsonDocument<200> jsonBuffer; //聲明一個JsonDocument對象,長度200
// 添加對象節(jié)點
jsonBuffer["key1"] = 123; // 整數(shù)
jsonBuffer["key2"] = 123.123; // 浮點數(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é)點
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[] = 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)驗給大家。
esp8266基于Arduino的開發(fā)教程匯總:https://blog.csdn.net/ShenZhen_zixian/article/details/121659482
還有什么問題的話,歡迎在評論區(qū)留言。如果這篇文章能夠幫到你,就…你懂得。