Валидация JSON в PHP

Валидация JSON в PHP является важным аспектом для обеспечения того, чтобы данные, поступающие из внешних источников, были корректными и соответствовали ожидаемой структуре. В PHP 8 добавлены улучшенные возможности для работы с JSON, что делает процесс валидации более удобным и мощным. В этой статье мы рассмотрим, как можно провести валидацию JSON в PHP 8, используя встроенные функции и дополнительные библиотеки.

PHP предоставляет функции для кодирования и декодирования JSON через функции json_encode и json_decode. Начнем с простого примера:

$jsonString = '{"name": "Michael", "age": 30, "city": "New York"}';

// Декодирование JSON строки в ассоциативный массив
$data = json_decode($jsonString, true);

if (json_last_error() !== JSON_ERROR_NONE) {
    echo "Ошибка декодирования JSON: " . json_last_error_msg();
} else {
    print_r($data);
}

Начиная с PHP 8.3, в языке появилась новая функция json_validate, которая позволяет проверить, является ли строка допустимым JSON, без необходимости её декодирования. Эта функция полезна, когда вам нужно убедиться в корректности JSON данных перед их обработкой. Использование json_validate делает процесс валидации более эффективным, так как вы можете проверить JSON на корректность без затрат на его парсинг.

Пример использования json_validate

$jsonString = '{"name": "John", "age": 30, "city": "New York"}';

if (json_validate($jsonString)) {
    echo "Строка является допустимым JSON.n";
} else {
    echo "Строка не является допустимым JSON.n";
    echo "Ошибка JSON: " . json_last_error_msg() . "n";
}

Обработка ошибок

Функция json_validate возвращает true, если строка является допустимым JSON, и false в противном случае. При этом можно использовать json_last_error и json_last_error_msg для получения информации об ошибке:

<?php
$jsonString = '{"name": "John", "age": 30, "city": "New York"'; // Ошибка в JSON (отсутствует закрывающая скобка)

if (!json_validate($jsonString)) {
    echo "Строка не является допустимым JSON.n";
    echo "Ошибка JSON: " . json_last_error_msg() . "n";
} else {
    echo "Строка является допустимым JSON.n";
}

Преимущества использования json_validate

  1. Эффективность: Позволяет проверить корректность JSON без его декодирования.
  2. Простота: Легко интегрируется в существующие скрипты для дополнительной проверки данных.
  3. Безопасность: Уменьшает вероятность обработки некорректных данных, улучшая общую устойчивость приложения.

Валидация структуры (схемы) JSON

Одним из способов валидации JSON является проверка структуры данных. Рассмотрим пример, когда мы ожидаем, что JSON должен содержать определенные ключи и их типы:

function validateJsonStructure(array $data, array $schema): bool {
    foreach ($schema as $key => $type) {
        if (!array_key_exists($key, $data)) {
            echo "Ключ '$key' отсутствует в данных.n";
            return false;
        }
        if (gettype($data[$key]) !== $type) {
            echo "Ключ '$key' должен быть типа '$type'.n";
            return false;
        }
    }
    return true;
}

$jsonString = '{"name": "Michael", "age": 30, "city": "New York"}';
$data = json_decode($jsonString, true);

if (json_last_error() !== JSON_ERROR_NONE) {
    echo "Ошибка декодирования JSON: " . json_last_error_msg();
} else {
    $schema = [
        'name' => 'string',
        'age' => 'integer',
        'city' => 'string'
    ];

    if (validateJsonStructure($data, $schema)) {
        echo "JSON данные валидны.n";
    } else {
        echo "JSON данные не соответствуют ожидаемой структуре.n";
    }
}

Использование JSON Schema для валидации

Для более сложной валидации можно использовать JSON Schema, который позволяет описывать ожидаемую структуру JSON документов. Существует несколько библиотек для PHP, которые поддерживают валидацию JSON Schema, например, justinrainbow/json-schema.

Установка библиотеки:

composer require justinrainbow/json-schema

Пример использования библиотеки для валидации JSON:

require 'vendor/autoload.php';

use JsonSchemaValidator;
use JsonSchemaConstraintsConstraint;

$jsonString = '{"name": "Michael", "age": 30, "city": "New York"}';
$data = json_decode($jsonString);

$schema = json_decode('{
    "type": "object",
    "properties": {
        "name": {"type": "string"},
        "age": {"type": "integer"},
        "city": {"type": "string"}
    },
    "required": ["name", "age", "city"]
}');

$validator = new Validator();
$validator->validate($data, $schema, Constraint::CHECK_MODE_APPLY_DEFAULTS);

if ($validator->isValid()) {
    echo "JSON данные валидны.n";
} else {
    echo "JSON данные не соответствуют ожидаемой структуре:n";
    foreach ($validator->getErrors() as $error) {
        echo sprintf("[%s] %sn", $error['property'], $error['message']);
    }
}

Валидация JSON в PHP 8 может быть выполнена различными способами, начиная от ручной проверки структуры данных до использования мощных инструментов, таких как JSON Schema. Выбор подхода зависит от сложности и требований вашего проекта. Использование JSON Schema и соответствующих библиотек позволяет значительно упростить процесс валидации и сделать его более гибким и надежным.

Еще больше о PHP я рассказываю в моем видеокурсе «PHP и MySQL с Нуля до Гуру 3.0»

Источник