Sin descripción

Benoit Blanchon 5e5f060fc0 Updated copyright for 2015 hace 11 años
examples e2016cf65b Added an example with EthernetServer hace 11 años
include 5e5f060fc0 Updated copyright for 2015 hace 11 años
scripts d6974127b4 Moved documentation to the wiki hace 11 años
src 5e5f060fc0 Updated copyright for 2015 hace 11 años
test 5e5f060fc0 Updated copyright for 2015 hace 11 años
third-party 5c8283b3e4 Added cpplint hace 11 años
.gitignore 24b46af48a Moved build output to bin/ and lib/ hace 11 años
.travis.yml 02960f28e4 Fix coveralls command line hace 11 años
CHANGELOG.md 8db338ba14 Removed global new operator overload (issue #40, #45 and #46) hace 11 años
CMakeLists.txt 160ce092ff Added code coverage badge hace 11 años
LICENSE.md 7a3fa35bd8 Added LICENSE.md hace 11 años
README.md 160ce092ff Added code coverage badge hace 11 años
keywords.txt a7b366e74f Updated for v4.0 hace 11 años
library.json 160ff0961e Added PlatformIO manifest file hace 11 años
library.properties 699292b058 Arduino example are now compiling hace 11 años

README.md

Arduino JSON library

Build Status Coverage Status

An elegant and efficient JSON library for embedded systems.

It's design to have the most intuitive API, the smallest footprint and works without any allocation on the heap (no malloc).

It has been written with Arduino in mind, but it isn't linked to Arduino libraries so you can use this library in any other C++ project.

Features

  • JSON decoding
  • JSON encoding (with optional indentation)
  • Elegant API, very easy to use
  • Fixed memory allocation (no malloc)
  • Small footprint
  • MIT License

Quick start

Decoding / Parsing

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];

Encoding / Generating

StaticJsonBuffer<200> jsonBuffer;

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

JsonArray& data = root.createNestedArray("data");
data.add(48.756080, 6);  // 6 is the number of decimals to print
data.add(2.302038, 6);   // if not specified, 2 digits are printed

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

Documentation

The documentation is available online in the Arduino JSON wiki

Testimonials

From Arduino's Forum user jflaplante:

I tried aJson json-arduino before trying your library. I always ran into memory problem after a while. I have no such problem so far with your library. It is working perfectly with my web services.

From Arduino's Forum user gbathree:

Thanks so much - this is an awesome library! If you want to see what we're doing with it - the project is located at www.photosynq.org.

From StackOverflow user thegreendroid:

It has a really elegant, simple API and it works like a charm on embedded and Windows/Linux platforms. We recently started using this on an embedded project and I can vouch for its quality.

From GitHub user zacsketches:

Thanks for a great library!!! I've been watching you consistently develop this library over the past six months, and I used it today for a publish and subscribe architecture designed to help hobbyists move into more advanced robotics. Your library allowed me to implement remote subscription in order to facilitate multi-processor robots. ArduinoJson saved me a week's worth of time!!


Found this library useful? Help me back with a donation! :smile: