Uh oh!
There was an error while loading.Please reload this page.
- Notifications
You must be signed in to change notification settings - Fork898
The fastest JSON schema Validator. Supports JSON Schema draft-04/06/07/2019-09/2020-12 and JSON Type Definition (RFC8927)
License
ajv-validator/ajv
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
The fastest JSON validator for Node.js and browser.
Supports JSON Schema draft-04/06/07/2019-09/2020-12 (draft-04 support requires ajv-draft-04 package) and JSON Type DefinitionRFC8927.
More than 100 people contributed to Ajv, and we would love to have you join the development. We welcome implementing new features that will benefit many users and ideas to improve our documentation.
Please reviewContributing guidelines andCode components.
All documentation is available on theAjv website.
Some useful site links:
- Getting started
- JSON Schema vs JSON Type Definition
- API reference
- Strict mode
- Standalone validation code
- Security considerations
- Command line interface
- Frequently Asked Questions
Pleasesponsor Ajv development
Since I asked to support Ajv development 40 people and 6 organizations contributed via GitHub and OpenCollective - this support helped receiving the MOSS grant!
Your continuing support is very important - the funds will be used to develop and maintain Ajv once the next major version is released.
Please sponsor Ajv via:
- GitHub sponsors page (GitHub will match it)
- Ajv Open Collective
Thank you.
Ajv generates code to turn JSON Schemas into super-fast validation functions that are efficient for v8 optimization.
Currently Ajv is the fastest and the most standard compliant validator according to these benchmarks:
- json-schema-benchmark - 50% faster than the second place
- jsck benchmark - 20-190% faster
- z-schema benchmark
- themis benchmark
Performance of different validators byjson-schema-benchmark:
- Ajv implements JSON Schemadraft-06/07/2019-09/2020-12 standards (draft-04 is supported in v6):
- all validation keywords (seeJSON Schema validation keywords)
- OpenAPI extensions:
- NEW: keyworddiscriminator.
- keywordnullable.
- full support of remote references (remote schemas have to be added with
addSchema
or compiled to be available) - support of recursive references between schemas
- correct string lengths for strings with unicode pairs
- JSON Schemaformats (withajv-formats plugin).
- validates schemas against meta-schema
- NEW: supportsJSON Type Definition:
- all keywords (seeJSON Type Definition schema forms)
- meta-schema for JTD schemas
- "union" keyword and user-defined keywords (can be used inside "metadata" member of the schema)
- supportsbrowsers and Node.js 10.x - current
- asynchronous loading of referenced schemas during compilation
- "All errors" validation mode withoption allErrors
- error messages with parameters describing error reasons to allow error message generation
- i18n error messages support withajv-i18n package
- removing-additional-properties
- assigning defaults to missing properties and items
- coercing data to the types specified in
type
keywords - user-defined keywords
- additional extension keywords withajv-keywords package
- $data reference to use values from the validated data as values for the schema keywords
- asynchronous validation of user-defined formats and keywords
To install version 8:
npm install ajv
Try it in the Node.js REPL:https://runkit.com/npm/ajv
In #"auto" data-snippet-clipboard-copy-content="// or ESM/TypeScript importimport Ajv from "ajv"// Node.js require:const Ajv = require("ajv")const ajv = new Ajv() // options can be passed, e.g. {allErrors: true}const schema = { type: "object", properties: { foo: {type: "integer"}, bar: {type: "string"}, }, required: ["foo"], additionalProperties: false,}const data = { foo: 1, bar: "abc",}const validate = ajv.compile(schema)const valid = validate(data)if (!valid) console.log(validate.errors)">
// or ESM/TypeScript importimportAjvfrom"ajv"// Node.js require:constAjv=require("ajv")constajv=newAjv()// options can be passed, e.g. {allErrors: true}constschema={type:"object",properties:{foo:{type:"integer"},bar:{type:"string"},},required:["foo"],additionalProperties:false,}constdata={foo:1,bar:"abc",}constvalidate=ajv.compile(schema)constvalid=validate(data)if(!valid)console.log(validate.errors)
Learn how to use Ajv and see more examples in theGuide: getting started
Seehttps://github.com/ajv-validator/ajv/releases
Please note:Changes in version 8.0.0
Please review and follow theCode of conduct.
Please report any unacceptable behaviour toajv.validator@gmail.com - it will be reviewed by the project team.
To report a security vulnerability, please use theTidelift security contact.Tidelift will coordinate the fix and disclosure. Please do NOT report security vulnerabilities via GitHub issues.
Ajv is a part ofTidelift subscription - it provides a centralised support to open-source software users, in addition to the support provided by software maintainers.
About
The fastest JSON schema Validator. Supports JSON Schema draft-04/06/07/2019-09/2020-12 and JSON Type Definition (RFC8927)
Topics
Resources
License
Code of conduct
Security policy
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Sponsor this project
Uh oh!
There was an error while loading.Please reload this page.