Внешняя компонента JSON-валидатор

09.01.23

Разработка - Разработка внешних компонент

Внешняя компонента под ОС семейства windows, реализующая функционал по проверке соответствия json-пакета заданной схеме ("Валидация").

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Внешняя компонента JSON-валидатор.:
.zip 279,28Kb
6
6 Скачать (1 SM) Купить за 1 850 руб.

wts: https://otus.ru/journal/schema-json-i-comments-chto-nuzhno-znat/ (в разделе "JSON Schema") или даже лучше: https://habr.com/ru/post/495766/.

Где может потребоваться: в тех ситуациях, когда нет уверенности, что придет JSON с тем составом и форматом полей или коллекций, который ожидается. Например, когда информация получается от неопределенного круга источников или когда нет уверенности в источнике.

Короче, согласно https://json-schema.org/, benefits такие:
1.Describes your existing data format(s).
2. Provides clear human- and machine- readable documentation.
3. Validates data which is useful for:
    3.1 Automated testing.
    3.2 Ensuring quality of client submitted data.

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

&НаКлиенте
Процедура JVD_validate(Команда)
    
    УстановитьВнешнююКомпоненту("ОбщийМакет.C1ExternTools");
	Рез = ПодключитьВнешнююКомпоненту("ОбщийМакет.C1ExternTools", "test", ТипВнешнейКомпоненты.Native);

	ВК =  Новый("AddIn.test.ExternToolsDRV");

    Схема = "{
    |""$id"": ""tsdGoodsPosting"",
    |""description"": ""Данные о товаре, поступившем на точку в рамках маршрутного листа"",
    |""type"": ""object"",
    |""properties"": {
    |    ""ДатаДок"": {
    |        ""type"": ""string"",
    |        ""pattern"": ""^20\\d{6}$""
    |    },
    |    ""НомерДок"": {
    |        ""type"": ""string""
    |    },
    |    ""Товары"": {
    |        ""type"": ""array"",
    |        ""items"": {
    |            ""$ref"": ""#/definitions/good""
    |        }
    |    }
    |},
    |""definitions"": {
    |    ""good"": {
    |        ""type"": ""object"",
    |        ""required"": [
    |            ""Товар_КодНСИ"",
    |            ""ЕИ""
    |        ],
    |        ""properties"": {
    |            ""Товар_КодНСИ"": {
    |                ""type"": ""string"",
    |                ""description"": """"
    |            },
    |            ""ЕИ"": {
    |                ""type"": ""string"",
    |                ""description"": """"
    |            }
    |        }
    |    }
    |}
    |}";
    
    
    ДанныеОк = "
    |{
    |""ДатаДок"": ""20221125"",
    |""НомерДок"": ""005-00001315"",
    |""Товары"": [
    |    {
    |        ""Товар_КодНСИ"": ""90000013"",
    |        ""ЕИ"": """"
    |    },
    |    {
    |        ""Товар_КодНСИ"": ""90012291"",
    |        ""ЕИ"": """"
    |    }
    |]
    |}";
    
    стрДжей = 	ВК.JVD_Проверить(Схема, ДанныеОк);
    
    стк = JSON.РазобратьJSON(стрДжей);
    
    ПоказатьПредупреждение(,стрДжей);
    
    ДанныеНЕОк = "
    |{
    |""ДатаДок"": ""30221125"",
    |""НомерДок"": ""005-00001315"",
    |""Товары"": [
    |    {
    |        ""Товар_КодНСИ"": ""90000013"",
    |        ""ЕИ"": """"
    |    },
    |    {
    |        ""Товар_КодНСИ"": ""90012291""
    |    }
    |]
    |}";
    
    стрДжей = 	ВК.JVD_Проверить(Схема, ДанныеНЕОк);
    
    стк = JSON.РазобратьJSON(стрДжей);
    
    ПоказатьПредупреждение(,стрДжей);
КонецПроцедуры

ОТВЕТЫ:
1. {"Data":"","Description":["OK"],"Status":true}
2. {"Data":"","Description":["Отсутствует обязательное поле 'ЕИ'. Объект: <root> --> [Товары] --> [1]","Провалена валидация значения на соответствие выражению RegEx. Объект: <root> --> [ДатаДок]"],"Status":false}

ИМХО технология - огонь. В среде 1с, она не слишком известна и востребована. Однако, быстрая валидация json по схемам очень будет полезной при обмене через rest+json.

P.S. Библиотеки jsoncpp и valijson переведены мной на русский язык в одно лицо, так-что прошу прощения, если где-то перевод не слишком точен.

P.P.S. ВК для Android здесь: //infostart.ru/public/1544296/

Тестировалось на платформе: 8.3.20.1674

Исходники: https://github.com/KotVezdehod/ExternToolsDRV

Валидатор JSON

См. также

Разработка внешних компонент Программист Платформа 1С v8.3 1C:Бухгалтерия Платные (руб)

Позволяет автоматизировать работу с картинками. С помощью компоненты можно измерять размер изображений, поворачивать их, наносить водяные знаки, конвертировать из одного формата в другой. Будет очень полезна для интернет-магазинов и всех, кому постоянно требуется работать с различными графическими форматами. Выполнена по технологии NativeAPI. Работает с форматами: jpg (jpeg), png, bmp, gif, tif

3600 руб.

02.09.2010    77822    73    257    

191

Разработка внешних компонент Программист Платформа 1С v8.3 1C:Бухгалтерия 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 Платные (руб)

Внешняя компонента позволяет работать c TWAIN-совместимым оборудованием (сканерами, камерами) . Полностью совместима со стандартной TWAIN-компонентой из БСП и может применяться как ее замена без изменения вызовов, при этом может работать с 64-разрядной платформой, а так же имеет расширенную функциональность, например, сохранение результата непосредственно в PDF без использования сторонних утилит. Прекрасно работает на сервере, тонком клиенте и веб-клиенте (проверена работа в браузерах Google Chrome, Mozilla Firefox и Microsoft Internet Explorer).

3000 руб.

12.05.2020    29149    139    100    

92

Разработка внешних компонент Программист Платформа 1С v8.3 1C:Бухгалтерия Платные (руб)

Внешняя компонента позволяет печатать PDF файлы непосредственно из 1С, не используя при этом сторонних программ. Прекрасно работает на сервере, тонком клиенте и веб-клиенте. Основана на проекте PDFium из состава проекта Chromium/Chrome

1500 руб.

17.09.2018    37160    115    128    

116

Разработка внешних компонент Программист Платформа 1С v8.3 1C:Бухгалтерия 1С:Управление торговлей 11 Платные (руб)

Внешняя компонента для конвертации PDF файлов в картинки без использования дополнительных программ. Работает на сервере и в тонком клиенте.

2400 руб.

25.06.2024    1329    3    4    

3

Разработка внешних компонент Системный администратор Программист Стажер Бесплатно (free)

Библиотека для работы с базами SQLite из 1С на основе внешней компоненты. Для Linux и Windows, бесплатно и с открытым исходным кодом!

14.01.2025    2716    bayselonarrend    14    

48

Разработка внешних компонент Программист Платформа 1С v8.3 1C:Бухгалтерия Россия Бесплатно (free)

В статье описывается приложение-конструктор внешних компонент (native API). Конструктор упрощает процесс разработки за счет удобного добавления всех нужных функций и процедур в графическом режиме, с указанием их параметров и типов параметров. На выходе приложение генерирует готовый код на С++ и Rust и позволяет сразу приступить к реализации, без настройки API компоненты вручную.

04.12.2024    5471    kovalevdmv    26    

77

Разработка внешних компонент Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Бесплатно (free)

Некоторые практические аспекты создания внешних компонент на языке С++ для платформы 1С 8.3++.

26.01.2024    7893    starik-2005    40    

47
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Поручик 4669 27.01.23 08:14 Сейчас в теме
Судя по нескольким страницам комментариев, технология в среде 1С востребована.
Потребности в валидации JSON-данных у меня за несколько лет действительно не возникало, так как источники данных известны, типы данных оговорены. Но самое главное, никогда не встречал и даже не слышал, что есть схемы для JSON по типу пакетов XDTO.
2. Prometeus2011 177 27.01.23 10:26 Сейчас в теме
(1) Примерно месяц назад, тоже не знал, что есть схемы для описания JSON).
В организации, для которой приходится сейчас писать софт, очень развесистая структура микросервисов, связанных между собой через REST. Организация занимается непростым и динамичным бизнесом - на стыке торговли и оказания услуг, который постоянно кипит... Вместе с бизнесом бурлят микросервисы и штат программистов. В такой среде часто возникают ошибки, которые отлавливаются специальным отделом тех. контроля. Чтобы предельно быстро понять, где укоренилось зло - валидация пакетов помогает.
Ну и схемы данных можно собрать в одном месте, однако на это требуется воля, которой пока нет.
Ситуация, конечно, не рядовая.
Оставьте свое сообщение