No Description

Benoit Blanchon 9bbfbd0a6a Set version to 6.2.1-beta 7 years ago
.github 7626db624e Changed all link to point to HTTPS version 8 years ago
examples 87fa87d87b Renamed function `RawJson()` to `serialized()` 7 years ago
fuzzing a9a730fd74 Added MessagePack fuzzing 7 years ago
scripts c3403ed72d Fixed conflicts with `isnan()` and `isinf()` macros (fixes #752) 7 years ago
src 9bbfbd0a6a Set version to 6.2.1-beta 7 years ago
test 6bb17d5896 Checked that issue issue #628 is fixed 7 years ago
third-party 5c33fd4b94 Set copyright year to 2018 8 years ago
.clang-format 8c7edbd9c3 ArduinoJson is now a header-only library (issue #199) 9 years ago
.gitattributes e31d667bec Added support of comments in JSON input (issue #88) 10 years ago
.gitignore fc2e3a4ab3 Added `serializeMsgPack()` and `measureMsgPack()` (closes #358) 7 years ago
.mbedignore 3fd87e8e82 Added fuzzing/ to .mbedignore 9 years ago
.travis.yml c3403ed72d Fixed conflicts with `isnan()` and `isinf()` macros (fixes #752) 7 years ago
ArduinoJson.h 5c33fd4b94 Set copyright year to 2018 8 years ago
CHANGELOG.md 9bbfbd0a6a Set version to 6.2.1-beta 7 years ago
CMakeLists.txt 5c33fd4b94 Set copyright year to 2018 8 years ago
CONTRIBUTING.md 6df204cf40 Split CONTRIBUTING and SUPPORT 8 years ago
LICENSE.md 5c33fd4b94 Set copyright year to 2018 8 years ago
README.md dc13882624 Update badges to show status of branch 6.x 7 years ago
SUPPORT.md fbfdca1de9 Added campaign information in links 8 years ago
appveyor.yml 4fe2b1100e Set version to 6.0.1-beta 7 years ago
banner.svg d6e61cbcda Added banner with the new logo 8 years ago
keywords.txt f53fc3e06f Added MessagePack in README 7 years ago
library.json 9bbfbd0a6a Set version to 6.2.1-beta 7 years ago
library.properties 9bbfbd0a6a Set version to 6.2.1-beta 7 years ago

README.md

ArduinoJson


Build status Build Status Coverage Status Star this project

ArduinoJson is a C++ JSON library for Arduino and IoT (Internet Of Things).

Features

  • JSON decoding (comments are supported)
  • JSON encoding (with optional indentation)
  • MessagePack
  • Elegant API, easy to use
  • Fixed memory allocation (zero malloc)
  • No data duplication (zero copy)
  • Portable (written in C++98, can be used in any C++ project)
  • Self-contained (no external dependency)
  • Small footprint
  • Input and output streams
  • 100% code coverage
  • Header-only library
  • MIT License
  • Comprehensive documentation

Compatibility

ArduinoJson works on the following hardware:

ArduinoJson compiles with zero warning on the following compilers, IDEs, and platforms:

Quickstart

Deserialization

Here is a program that parses a JSON document with ArduinoJson.

char json[] = "{\"sensor\":\"gps\",\"time\":1351824120,\"data\":[48.756080,2.302038]}";

DynamicJsonDocument doc;
deserializeJson(doc, json);

JsonObjectRef root = doc.as<JsonObject>();
const char* sensor = root["sensor"];
long time          = root["time"];
double latitude    = root["data"][0];
double longitude   = root["data"][1];

See the tutorial on arduinojson.org

Serialization

Here is a program that generates a JSON document with ArduinoJson:

DynamicJsonDocument doc;

JsonObject root = doc.to<JsonObject>();
root["sensor"] = "gps";
root["time"] = 1351824120;

JsonArray data = root.createNestedArray("data");
data.add(48.756080);
data.add(2.302038);

serializeJson(doc, Serial);
// This prints:
// {"sensor":"gps","time":1351824120,"data":[48.756080,2.302038]}

See the tutorial on arduinojson.org

Documentation

The documentation is available on arduinojson.org, here are some shortcuts:

  • The Examples show how to use the library in various situations.
  • The API Reference contains the description of each class and function.
  • The FAQ has the answer to virtually every question.
  • The ArduinoJson Assistant writes programs for you!

Do you like this library? Please star this project on GitHub!

What? You don't like it but you love it? We don't take donations anymore, but we sell a book, so you can help and learn at the same time!