Загрузка...
Загрузка...
JSON Schema: draft-07, 2020-12. Ключевые слова type, properties, required. Примеры валидации пользователя и API-контракта. Ajv, OpenAPI.
Сравнение YAML и JSON: синтаксис, преимущества, конвертация. Примеры для Docker Compose, Kubernetes, CI/CD. Онлайн-конвертер YAML ↔ JSON.
РазработкаРуководство по работе с JSON в REST API: парсинг ответов, валидация структуры, обработка ошибок и рекомендации для фронтенда и бэкенда.
РазработкаРуководство по типичным ошибкам в JSON: синтаксис, валидация, инструменты поиска и исправления некорректных данных.
Веб-разработкаПодробное руководство по работе с JSON: валидация, форматирование, минификация и обработка ошибок. Практические примеры и лучшие практики для веб-разработчиков.
Поделитесь с коллегами или изучите другие материалы блога
JSON Schema — язык описания структуры и ограничений JSON-данных. Схема задаёт типы полей, обязательность, диапазоны значений, форматы строк и вложенные объекты. На основе схемы можно валидировать входящие данные, генерировать документацию и типы для TypeScript, описывать контракты API. В этой статье разберём версии JSON Schema (draft-07, 2020-12), основные ключевые слова, практические примеры, библиотеки и интеграцию с OpenAPI.
Для проверки JSON по схеме используйте JSON Schema Validator на reChecker.
JSON Schema — это сам по себе JSON-документ, описывающий допустимую структуру других JSON-документов. Схема отвечает на вопросы: какие поля обязательны, какие типы у значений, какие ограничения (минимум, максимум, паттерны, форматы).
$dynamicRef, $anchor, условные схемы, улучшенная работа с null.В $schema указывают версию:
{
"$schema": "https://json-schema.org/draft/2020-12/schema"
}
или для draft-07:
{
"$schema": "http://json-schema.org/draft-07/schema#"
}
Тип значения: string, number, integer, boolean, array, object, null.
{
"type": "string"
}
Несколько типов — массив:
{
"type": ["string", "null"]
}
properties — описание полей объекта. additionalProperties — разрешать ли поля, не перечисленные в properties.
{
"type": "object",
"properties": {
"name": { "type": "string" },
"age": { "type": "integer" }
},
"additionalProperties": false
}
Массив обязательных полей:
{
"type": "object",
"properties": {
"email": { "type": "string", "format": "email" },
"password": { "type": "string", "minLength": 8 }
},
"required": ["email", "password"]
}
{
"type": "string",
"minLength": 1,
"maxLength": 100,
"pattern": "^[a-zA-Z0-9_]+$",
"format": "email"
}
Популярные format: email, uri, date, date-time, uuid, ipv4, ipv6.
{
"type": "integer",
"minimum": 0,
"maximum": 120,
"exclusiveMaximum": true
}
{
"type": "array",
"items": { "type": "string" },
"minItems": 1,
"maxItems": 10
}
Для кортежей (разные типы по позициям) — массив в items:
{
"type": "array",
"items": [
{ "type": "string" },
{ "type": "integer" }
]
}
Допустимые значения:
{
"type": "string",
"enum": ["draft", "published", "archived"]
}
Переиспользование схем:
{
"$defs": {
"address": {
"type": "object",
"properties": {
"street": { "type": "string" },
"city": { "type": "string" }
}
}
},
"type": "object",
"properties": {
"shipping": { "$ref": "#/$defs/address" },
"billing": { "$ref": "#/$defs/address" }
}
}
{
"$schema": "https://json-schema.org/draft/2020-12/schema",
"type": "object",
"properties": {
"id": { "type": "string", "format": "uuid" },
"email": { "type": "string", "format": "email" },
"name": { "type": "string", "minLength": 1, "maxLength": 100 },
"age": { "type": "integer", "minimum": 0, "maximum": 150 },
"role": { "type": "string", "enum": ["user", "admin", "moderator"] }
},
"required": ["email", "name"],
"additionalProperties": false
}
{
"type": "object",
"properties": {
"query": { "type": "string" },
"page": { "type": "integer", "minimum": 1, "default": 1 },
"limit": { "type": "integer", "minimum": 1, "maximum": 100, "default": 20 }
},
"required": ["query"]
}
{
"type": "object",
"properties": {
"user": {
"type": "object",
"properties": {
"name": { "type": "string" },
"address": {
"type": "object",
"properties": {
"city": { "type": "string" },
"zip": { "type": "string", "pattern": "^[0-9]{5,6}$" }
}
}
}
}
}
}
Популярная библиотека валидации:
import Ajv from 'ajv';
const ajv = new Ajv();
const validate = ajv.compile(schema);
const valid = validate(data);
if (!valid) console.log(validate.errors);
import jsonschema
jsonschema.validate(instance=data, schema=schema)
OpenAPI 3.x использует подмножество JSON Schema для описания тел запросов и ответов. Схемы в components.schemas — это JSON Schema с небольшими отличиями. Инструменты вроде Swagger UI и генераторы клиентов опираются на эти схемы. При миграции с OpenAPI 2.0 (Swagger) на 3.x проверьте совместимость ключевых слов — в 2.0 использовалась устаревшая версия схемы.
Из JSON Schema можно генерировать типы TypeScript, классы для валидации, формы и документацию. Популярные инструменты: quicktype, json-schema-to-typescript, openapi-generator. Это сокращает ручную работу и снижает расхождения между схемой и кодом.
Для сложной логики валидации используются условные конструкции:
if, применяется then, иначе elseПример: поле type определяет обязательные поля:
{
"if": { "properties": { "type": { "const": "company" } }, "required": ["type"] },
"then": { "required": ["companyName"] },
"else": { "required": ["firstName", "lastName"] }
}
Валидатор JSON Schema на reChecker позволяет:
Инструмент поддерживает draft-07 и 2020-12. Удобен для разработчиков при написании и отладке схем, а также при разборе ошибок валидации.
additionalProperties: true по умолчанию допускает лишние поля; для API лучше явно запрещать$defs или во внешнем файлеformat по умолчанию; в Ajv нужно подключать format отдельно$schema явноfalsetitle и description к полям для автогенерации документации2020-12 добавляет $dynamicRef, $anchor, улучшенную поддержку null и условных схем. Для большинства задач draft-07 достаточно. Выбирайте 2020-12, если нужны новые возможности или совместимость с актуальными инструментами.
Да. Инструменты вроде json-schema-to-typescript генерируют типы TypeScript из схемы. Также существуют библиотеки для runtime-валидации с выводом типов (например, Zod, который не является JSON Schema, но решает похожие задачи).
Используйте oneOf, anyOf или allOf в items:
{
"type": "array",
"items": {
"oneOf": [
{ "type": "object", "properties": { "type": { "const": "A" } } },
{ "type": "object", "properties": { "type": { "const": "B" } } }
]
}
}
OpenAPI 3.x использует подмножество JSON Schema. Не поддерживаются, например, $ref на внешние файлы в произвольных местах, часть ключевых слов. Для сложных схем проверяйте документацию OpenAPI.
JSON Schema Validator на reChecker — бесплатный онлайн-инструмент. Вставьте JSON и схему, получите результат валидации и список ошибок с путями. Поддерживает draft-07 и 2020-12. Подходит для разработчиков при написании схем и отладке API.