Интеграционная прослойка(middleware) на Golang. Часть 5 - Обмен с 1С через HTTP-сервисы платформы

18.06.21

Интеграция - WEB-интеграция

В этой статье научим прослойку отправлять данные в 1С, для этого используем HTTP-сервисы платформы. Обменяемся данными с новым справочником Клиенты. Но главное создадим HTTP-сервис для получения сообщений из очереди RabbitMQ.

Предыдущие и будущие статьи:

Итак имеем Платформу 8.3.17.1549, Веб-сервер IIS. Как и раньше используем шаблонный справочник(логический) Клиенты с полями (Идентификатор, Имя, Тип, Майл).

Создаем HTTP-сервис для обмена.

Создаем простенький справочник для хранения клиентов

Публикуем HTTP-сервис (не буду расписывать как это все поставить, тут очень много хороший статей описывающий этот процесс)

Данный HTTP-сервис позволяет удалять\добавлять\изменять данные из прослойки, код тоже стандартный JSON и методы GET, POST, DELETE

В прослойке добавил режим для 1С, а также адрес HTTP-сервиса

Получаем список из 1С

Помеченные не берем, можно записи удалить, изменить, добавить

Все изменения отражаются в 1С.

Теперь сделаем интеграцию с очередью RabbitMQ более правильной (Это статья №1 этого цикла)  теперь RabbitMQ будет сама отправлять входящие сообщения направляя их в HTTP-сервис платформы.

Создаем для этого отдельный HTTP-сервис

Основную роль играет метод POST, метод GET просто для проверки, что сервис корректно создан.

Суть реализации аналогичная, получаем сообщение из RabbitMQ с JSON записью Клиента, дальше его записываем в справочник Клиенты.

Можем из любой конфигурации отправить данные в RabbitMQ и получить в тестовой базе

Получаем это в тестовой базе, это отладка внутри HTTP-сервиса.

Записали в 1С

В прослойке тоже можем видеть эту запись, благодаря первому HTTP-сервису.

Я не стал заостряться на коде 1С он достаточно тривиальный, конфигурацию выложим на GitHub.

Относительно прослойки на Golang тоже ничего сверхзаумного, использовал стандартный пакет "net/http", функции http.Post() и http.Get() для метода DELETE и POST использовал функции http.NewRequest() т.к нужно было передавать параметры (Идентификатор клиента)

Например, кстати вижу тут очень неоптимальный код, кто заметит молодец! 

Адрес исходников GitHub https://github.com/dmitry-msk777/Connector_1C_Enterprise

ОБНОВЛЕНИЕ 06.10.2020

Добавлен шаблон получения данных справочника клиента по oData в слайз структур.

 

RabbitMQ Golang REST RESTful HTTP-сервисы oData

См. также

Интеграция Альфа Авто 5 / Альфа Авто 6 и AUTOCRM / Инфотек

Сайты и интернет-магазины WEB-интеграция Платформа 1С v8.3 Конфигурации 1cv8 1С:Управление торговлей 11 Автомобили, автосервисы Россия Управленческий учет Платные (руб)

Интеграционный модуль обмена между конфигурацией Альфа Авто 5 и Альфа Авто 6 и порталом AUTOCRM. Данный модуль универсален. Позволяет работать с несколькими обменами AUTOCRM разных брендов в одной информационной базе в ручном и автоматическом режиме.

36000 руб.

03.08.2020    15929    13    18    

13

Интеграция 1С — Битрикс24. Обмен задачами

Сайты и интернет-магазины Интеграция WEB-интеграция Платформа 1С v8.3 Конфигурации 1cv8 Управленческий учет Платные (руб)

Интеграция 1С и Битрикс24. Разработка имеет двухстороннюю синхронизацию 1С и Битрикс24 задачами. Решение позволяет создавать пользователя в 1С из Битрикс24 и наоборот. Данная разработка технически подходит под все основные конфигурации линейки продуктов 1С:Предприятие 8.3 (8.3.18.1289). При приобретении предоставляется 1 месяц бесплатных обновлений разработки. Доступна демо-версия продукта с подключением Вашего Битрикс24

5040 руб.

04.05.2021    17880    6    15    

13

Заполнение по ИНН или наименованию реквизитов контрагента по данным сайта ФНС

Обмен с ГосИС WEB-интеграция Платформа 1С v8.3 Управляемые формы 1С:Комплексная автоматизация 1.х 1С:Бухгалтерия 2.0 1С:Управление торговлей 10 1С:Управление производственным предприятием 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия государственного учреждения 1С:Документооборот 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Платные (руб)

Обработка является альтернативой механизму, разработанному фирмой 1С и заполняющему реквизиты контрагента по ИНН или наименованию. Не требуется действующей подписки ИТС. Вызывается как внешняя дополнительная обработка, т.е. используется, непосредственно, из карточки контрагента. Заполнение по ИНН или наименованию реквизитов контрагента по данным сайта ФНС (egrul.nalog.ru) для БП 2.0, БП 3.0, БГУ 1.0, БГУ 2.0, УТ 10.3, УТ 11.x, КА 1.1, КА 2.x, УПП 1.x, ERP 2.x, УНФ 1.5, УНФ 1.6, УНФ 3.0, ДО 2.1

2400 руб.

28.04.2016    88925    163    216    

318

[Расширение] БОР-Навигатор.Культура

Зарплата Бюджетный учет WEB-интеграция Обмен с ГосИС Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и кадры государственного учреждения 3 Государственные, бюджетные структуры Россия Бюджетный учет Платные (руб)

Расширение конфигурации, включающее в себя объекты, необходимые для подготовки и сдачи отчета "Штатная численность" системы "БОР-Навигатор.Культура" в программе "1С:Зарплата и кадры государственного учреждения", редакция 3.1.

8400 руб.

01.02.2019    25868    9    0    

7

Интеграция с сервисом vetmanager

WEB-интеграция Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Бытовые услуги, сервис Платные (руб)

Внешняя обработка разрабатывалась для загрузки документов из Ветменеджер в 1С: Бухгалтерия 3.0

12000 руб.

02.02.2021    16477    42    49    

23
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. SizovE 263 05.10.20 10:03 Сейчас в теме
Наверное не очень хорошо через файл JSON читать, думаю так удобнее
ЧтениеJSON = Новый ЧтениеJSON;
	ЧтениеJSON.УстановитьСтроку(Строка);
	
	Попытка
		Данные = ПрочитатьJSON(ЧтениеJSON);
	Исключение
		Возврат ОписаниеОшибки();
	КонецПопытки;	

Показать
Leon75; +1
2. dmitry-irk38 136 05.10.20 11:05 Сейчас в теме
(1) Когда-то на платформе было ограничение в 65000 символов(или строк) на УстановитьТелоКакСтроку в свое время на этом собаку съел, можно протестировать кончено, что сейчас со строками. Причем просто режет в наглую и ничего не говорит платформа.
Сейчас появилось ПолучитьТелоКакПоток, что я иногда использую, но УстановитьТелоКакПоток пока не реализовали видимо, это позволяет без создания файла через оперативку выполнять операции и вероятно избежать ограничения строка на 65000 символов.
+
3. SizovE 263 06.10.20 09:06 Сейчас в теме
(2) 1С как всегда забавна, в документации ни слова нет.
+
4. dmitry-irk38 136 06.10.20 11:09 Сейчас в теме
(3) Вот далеко ходить не нужно на днях у функции глобального контекста ВыгрузитьЖурналРегистрации() обнаружил, что если в параметр МаксимальноеКоличество задавать число меньшее 10 000, то он все равно будет всегда грузить 10 000. Узнал я это когда начал парсить выгружаемые файлы. В СП информации этой нет, в методической информации тоже нет. Я в начале вообще решил, что этот параметр не работает, когда вместо 50 записей, которые я выставил выгрузилась очень много, как оказалось 10 000
user1464234; +1
Оставьте свое сообщение