The ultra high-performance JSON Schema validator for C++ with support for JSON Schema Draft 4, Draft 6, Draft 7, 2019-09, and 2020-12.
Want to use Blaze without writing C++? Check out our JSON Schema CLI, which is powered by Blaze, and offers advanced functionality like validate --trace for debugging schema evaluation.
The 2025 paper Blaze: Compiling JSON Schema for 10x Faster Validation presents a reproducible benchmark comparing Blaze against a number of popular JSON Schema validators, concluding that Blaze is on average at least 10x faster than competitors given a large set of representative schemas and instances.
-
Performance: Blaze compiles JSON Schema into a lower-level intermediate language for ultra fast evaluation. It can achieve schema validation in the nano-second range, making it a perfect fit for low-latency gateways and validation of large datasets
-
Compliance: Blaze achieves a 100% compliance score in the official Bowtie benchmark, while popular validators like AJV only achieve an average 85% compliance. It also supports the Standard Output format (Flag, and Basic). Furthermore, Blaze is built and maintained by a JSON Schema TSC member
-
Extensibility: Blaze supports the implementation of custom vocabularies of arbitrary complexity, and the ability to setup custom resolution of external schemas from arbitrary sources, like from HTTP, filesystem, databases, etc
-
Annotations: Blaze is one of the few implementations that fully supports annotation extraction during evaluation to augment instances with semantic information, making it a great fit for data science scenarios. Blaze also adheres to the annotations official test suite
-
Numerics: Blaze supports high precision decimals. For performance reasons, these representations are only used if the numbers fail to be parsed at the JSON level using the 64-bit signed and IEEE 764 double precision representations or (as a heuristic) if the numbers explicitly opt-in to exponent scientific notation
Blaze is designed to be easy to use, while at the same time providing extensive hooks for supporting custom vocabularies, resolving external schemas, and more.
// (1) Get a JSON Schema const auto schema{sourcemeta::core::parse(R"JSON({ "$schema": "https://json-schema.org/draft/2020-12/schema", "type": "string" })JSON")}; // (2) Compile the JSON Schema into an optimised representation const auto compiled_schema{sourcemeta::blaze::compile( schema, // These options allow you tweak how Blaze works, // the JSON Schema vocabularies it understands, // and how to resolve references to external schemas sourcemeta::core::schema_official_walker, sourcemeta::core::schema_official_resolver, sourcemeta::blaze::default_schema_compiler, // Fast validation means getting to a boolean result // as fast as possible. Check out the documentation // for how to get detailed error information and/or // collect JSON Schema annotations sourcemeta::blaze::Mode::FastValidation)}; // (3) Get a JSON instance const sourcemeta::core::JSON instance{"Hello Blaze!"}; // (4) Validate the instance against the schema sourcemeta::blaze::Evaluator evaluator; const auto result{evaluator.validate(compiled_schema, instance)}; if (result) { std::cout << "Success!\n"; }Refer to the project website for documentation: https://blaze.sourcemeta.com.
- Support running the validator on simdjson
- Provide bindings to higher-level programming languages (Node.js, Go, etc)
Blaze was designed and developed by a team of passionate JSON Schema developers and researchers.
