ESP-1ch-Gateway-v5.0--OLD/libraries/ArduinoJson
platenspeler db10b060e8 Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
..
examples Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
fuzzing Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
scripts Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
src Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
test Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
third-party/catch Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
ArduinoJson.h Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
CHANGELOG.md Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
CMakeLists.txt Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
CONTRIBUTING.md Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
LICENSE.md Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
README.md Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
SUPPORT.md Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
appveyor.yml Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
banner.svg Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
keywords.txt Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
library.json Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00
library.properties Version 5.2.0; ESP32 support 2018-05-30 12:05:44 +02:00

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)
  • 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]}";

StaticJsonBuffer<200> jsonBuffer;

JsonObject& root = jsonBuffer.parseObject(json);

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:

StaticJsonBuffer<200> jsonBuffer;

JsonObject& root = jsonBuffer.createObject();
root["sensor"] = "gps";
root["time"] = 1351824120;

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

root.printTo(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!