Нет описания

Benoit Blanchon e0ce711eb4 Fixed cpplint warnings 11 лет назад
doc 99e5ff78f3 Removed empty document 11 лет назад
examples b4b475d692 Simplified generator example 11 лет назад
include e0ce711eb4 Fixed cpplint warnings 11 лет назад
scripts ac9b776aa1 Fixed remaining cpplint warnings 11 лет назад
src 0911d8d796 Fixed cpplint warnings 11 лет назад
test e0ce711eb4 Fixed cpplint warnings 11 лет назад
third-party 5c8283b3e4 Added cpplint 11 лет назад
.gitignore 24b46af48a Moved build output to bin/ and lib/ 11 лет назад
CHANGELOG.md dfac1cf71a Updated for v4.0 11 лет назад
CMakeLists.txt 7e98d136f4 Added more warning flags for GCC (as suggested in issue #28) 11 лет назад
LICENSE.md 7a3fa35bd8 Added LICENSE.md 11 лет назад
README.md 0c9451fd5f Updated for v4.0 11 лет назад
keywords.txt a7b366e74f Updated for v4.0 11 лет назад
library.properties 699292b058 Arduino example are now compiling 11 лет назад

README.md

Arduino JSON library

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

See complete guide

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

See complete guide

Testimonials

From Arduino's Forum user jflaplante:

I tried the [aJson and 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.