Как мне проверить JSON на схему Avro

У меня есть ответ в формате JSON от API, и я хотел бы выполнить проверку на соответствие существующей схеме Avro (строгая проверка с именами и типами).

Ответ имеет тип

{"name": "alex", "age": 23, "sex": "M", "active": "true"}

Схема имеет указанные выше типы с типами данных, и я хотел бы проверить схему и выдать исключение в случае сбоя (предпочтительно JAVA).

Я прочитал решение, использующее командную строку, но я хотел сделать это программно.

заранее спасибо

Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
6
0
11 442
1

Ответы 1

Вот как вы можете проверить это программно.

import org.apache.avro.AvroTypeException;
import org.apache.avro.Schema;
import org.apache.avro.generic.GenericDatumReader;
import org.apache.avro.io.DatumReader;
import org.apache.avro.io.Decoder;
import org.apache.avro.io.DecoderFactory;

import java.io.*;

public class MainClass {
    public static void main (String [] args) throws Exception {
        Schema schema = new Schema.Parser().parse("{\n" +
                "     \"type\": \"record\",\n" +
                "     \"namespace\": \"com.acme\",\n" +
                "     \"name\": \"Test\",\n" +
                "     \"fields\": [\n" +
                "       { \"name\": \"name\", \"type\": \"string\" },\n" +
                "       { \"name\": \"age\", \"type\": \"int\" },\n" +
                "       { \"name\": \"sex\", \"type\": \"string\" },\n" +
                "       { \"name\": \"active\", \"type\": \"boolean\" }\n" +
                "     ]\n" +
                "}");
        String json = "{\"name\":\"alex\",\"age\":23,\"sex\":\"M\",\"active\":true}";
        System.out.println(validateJson(json, schema));
        String invalidJson = "{\"name\":\"alex\",\"age\":23,\"sex\":\"M\"}"; // missing active field
        System.out.println(validateJson(invalidJson, schema));
    }

    public static boolean validateJson(String json, Schema schema) throws Exception {
        InputStream input = new ByteArrayInputStream(json.getBytes());
        DataInputStream din = new DataInputStream(input);

        try {
            DatumReader reader = new GenericDatumReader(schema);
            Decoder decoder = DecoderFactory.get().jsonDecoder(schema, din);
            reader.read(null, decoder);
            return true;
        } catch (AvroTypeException e) {
            System.out.println(e.getMessage());
            return false;
        }
    }
}

Я думаю, что это так, вы должны скопировать и вставить :)

hlagos 16.04.2019 04:16

Выполнение приведенного выше кода с тем же недопустимым json: Ожидается логическое значение. Получил END_OBJECT. Однако он не указал на «активное» поле.

Duc Tran 17.04.2019 23:29

Если отсутствующее поле не является последним полем в схеме, то оно указывает точное поле: «Ожидаемое имя поля не найдено: <поле>». Однако, если поле имеет неправильный тип данных, отображается неопределенное сообщение, например: «AvroTypeException: Expected int. Got VALUE_STRING»

Duc Tran 18.04.2019 00:53

Другие вопросы по теме