Интеграционная прослойка(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 разных брендов в одной информационной базе в ручном и автоматическом режиме. Без существенных изменений типовой конфигурации. Проверено с брендами: Интеграция 1С и GEELY Интеграция 1С и HAVAL Интеграция 1С и KIA Интеграция 1С и FORD Интеграция 1С и LADA ГАРАНТИЯ 100% ВНЕДРЕНИЯ!

36000 руб.

03.08.2020    15662    9    17    

9

Модуль для обмена "1С:Предприятие 8. УАТ. ПРОФ" с FortMonitor

WEB-интеграция 8.3.8 Конфигурации 1cv8 Автомобили, автосервисы Беларусь Украина Россия Казахстан Управленческий учет Платные (руб)

Расширение предназначено для конфигурации "1С:Предприятие 8. Управление Автотранспортом. ПРОФ". Функционал модуля: 1. Заполнение регистров сведений по подсистеме "Мониторинг", а именно: события по мониторингу, координаты по мониторингу, пробег и расход по мониторингу, текущее местоположение ТС по мониторингу 2. Заполнение путевого листа: пробег по мониторингу, время выезда/заезда, табличная часть ГСМ, места стоянок по геозонам. 3. Отчеты по данным загруженным в регистры сведений. 4. Предусмотрена автоматическая загрузка данных в фоновом режиме (условия работы данной загрузке читайте в описании товара) Модуль работает без включенной константы по настройкам мониторинга. Модуль формы предоставляется с открытым кодом, общий модуль защищен. Любой заинтересованный пользователь, имеет возможность скачать демо-версию расширения.

22656 руб.

25.05.2021    12810    30    8    

10

Интеграция 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    17430    6    15    

13

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

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

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

8400 руб.

01.02.2019    25688    9    0    

7

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

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

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

12000 руб.

02.02.2021    16260    41    49    

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

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