JSON Schema is a vocabulary that allows you to annotate and validate JSON documents.
Benefits
- Provides methods for working with data in JavaScript Object Notation (JSON) format.
- The JSON Formatter was created to help folks with debugging. As JSON data is often output without line breaks to save space, it can be extremely difficult to actually read and make sense of it. This tool hoped to solve the problem by formatting and beautifying the JSON.
- Describes your existing data format(s).
- Provides clear human- and machine- readable documentation.
- Validates data which is useful for:
- Automated testing.
- Ensuring quality of client submitted data.
Online JSON Formatter and Online JSON Validator also provides json converter tools to convert JSON to XML, JSON to CSV, and JSON to YAML also JSON Editor, JSONLint, JSON Checker and JSON Cleaner. JSON Formatter Online and JSON Validator Online work well in Windows, Mac, Linux, Chrome, Firefox, Safari, and Edge and it's free.
New to JSON Schema?
Learning a new specification can be daunting.
You should read our getting started guide!
You can also see our other learning resources.
Got questions?
The JSON Schema team and community are here to help!
At any point, feel free to join our Slack server.
We also monitor the jsonschema
tag on StackOverflow.
Project Status
2021-02-01: Draft 2020-12 has been published!
The IETF document IDs are of the form draft-bhutton-*-00
.
We are using dates for meta-schemas, which are what implementations should use to determine behavior,so we will usually refer to 2020-12
(without the word “draft”) on this web site.
See the Specification page for details about naming and numbering.
The Path to Standardization
The JSON Schema project intends to shepherd all three draft series to either: RFC status, the equivalent within another standards body, and/or join a foundation and establish self publication rules.
Currently, we are continuing to improve our self-published Internet-Drafts. We are not actively pursuing joining a standards organisation.
We have a few contacts related to each potential path, but if you have experience with such things and would like to help, please still contact us!
In the meantime, publication of Internet-Draft documents can be tracked through the IETF:
Internet-Drafts expire after six months, so our goal is to publish often enough to always have a set of unexpired drafts available. There may be brief gaps as we wrap up each draft and finalize the text.
The intention, particularly for vocabularies such as validation which have been widely implemented, is to remain as compatible as possible from draft to draft. However, these are still drafts, and given a clear enough need validated with the user community, major changes can occur.
Quickstart
The JSON document being validated or described we call the instance, and the document containing the description is called the schema.
The most basic schema is a blank JSON object, which constrains nothing, allows anything, and describes nothing:
You can apply constraints on an instance by adding validation keywords to the schema. For example, the “type” keyword can be used to restrict an instance to an object, array, string, number, boolean, or null:
JSON Schema is hypermedia ready, and ideal for annotating your existing JSON-based HTTP API. JSON Schema documents are identified by URIs, which can be used in HTTP Link headers, and inside JSON Schema documents to allow recursive definitions.
JSON Hyper-Schema
C# Json Class
JSON Hyper-Schema is on hiatus / not currently maintained as of 2021.
This allows the team to focus the little time they do donate on JSON Schema core and validation.
We may revisit JSON Hyper-Schema at a later date.
More
Interested? Check out:
Msdn Json
- The specification
- the growing list of JSON Schema software
Json Test Api
We encourage updating to the latest specification where possible, which is 2020-12.
Json Helper Laravel
Questions? Feeling helpful? Get involved on: