Функция MSSQL для вызова HTTP сервиса 1С

26.12.19

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

MSSQL вызывает какие-либо действия в 1С или получает оттуда информацию. В сторонних таблицах при вставке/обновлении/удалении строк срабатывает триггер. Процедура триггера дёргает предлагаемую функцию. Вызывается HTTP сервис 1С, который обрабатывает информацию об изменениях сторонних таблиц, либо возвращает информацию для записи.

Скрипт создания функции:

CREATE FUNCTION [dbo].[HTTPRequest] ( @postData nvarchar(max) )
RETURNS nvarchar(500)
AS
BEGIN
 
Declare @Object as Int;
Declare @ResponseText as nvarchar(500);
Declare @ResponseError as int;
DECLARE @source varchar(255), @desc varchar(255) 

Exec @ResponseError = sp_OACreate 'MSXML2.ServerXMLHTTP', @Object OUT ;
IF @ResponseError <> 0 BEGIN
      EXEC sp_OAGetErrorInfo @Object, @source OUT, @desc OUT
      RETURN '1 ' + @desc;
END

Exec @ResponseError = sp_OAMethod @Object, 'open', NULL, 'post',
    'http://localhost/<base>/hs/<rootUrl>/', 'false', '<user>', '<password>';
IF @ResponseError <> 0 BEGIN
      EXEC sp_OAGetErrorInfo @Object, @source OUT, @desc OUT
      RETURN '2 ' + @desc;
END

EXEC @ResponseError = sp_OAMethod @Object, 'setRequestHeader', NULL, 'Content-Type', 'application/x-www-form-urlencoded; charset=utf-8';
IF @ResponseError <> 0 BEGIN
      EXEC sp_OAGetErrorInfo @Object, @source OUT, @desc OUT
      RETURN '3 ' + @desc;
END

Exec @ResponseError = sp_OAMethod @Object, 'send', NULL, @postData;
IF @ResponseError <> 0 BEGIN
      EXEC sp_OAGetErrorInfo @Object, @source OUT, @desc OUT
      RETURN '4 ' + @desc;
END

Exec @ResponseError = sp_OAMethod @Object, 'responseText', @ResponseText OUTPUT;
IF @ResponseError <> 0 BEGIN
      EXEC sp_OAGetErrorInfo @Object, @source OUT, @desc OUT
      RETURN '5 ' + @desc;
END

Exec sp_OADestroy @Object;
 
RETURN @ResponseText
 
END

В скрипте необходимо указать свои данные подключения к HTTP сервису: URL, логин и пароль. Параметр функции - строка которую необходимо передать сервису. Возвращает строку полученную от сервиса либо ошибку.


Для проверки можно выполнить следующие команды со своим параметром:
Declare @ResponseText as nvarchar(max);
SET @ResponseText = dbo.HTTPRequest('zzz=yyy');
PRINT(@ResponseText);
 

Функционал тестировался в следующей конфигурации:

Microsoft Windows 2008 R2

Microsoft SQL Server Standard Edition (64-bit)   10.50.6529.0

1С:Предприятие 8.3 (8.3.9.2309)

Управление небольшой фирмой (1.2.3.71)

Вступайте в нашу телеграмм-группу Инфостарт

См. также

Сайты и интернет-магазины WEB-интеграция Системный администратор Программист Пользователь 1С:Предприятие 8 1C:Бухгалтерия 1С:Управление торговлей 11 Автомобили, автосервисы Россия Управленческий учет Платные (руб)

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

42700 руб.

03.08.2020    23766    36    24    

28

WEB-интеграция Программист 1С:Предприятие 8 1С:Бухгалтерия 3.0 Бытовые услуги, сервис Платные (руб)

Расширение для автоматизации передачи данных между сервисом Vetmanager с 1С: Бухгалтерия 3.0. Решение позволяет загружать документы и справочники из Ветменеджер в 1С:Бухгалтерию, сокращая время на ручной ввод данных и минимизируя ошибки.

24000 руб.

02.02.2021    22497    67    52    

42

WEB-интеграция Загрузка и выгрузка в Excel Программист Пользователь 1С:Предприятие 8 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Розничная и сетевая торговля (FMCG) Россия Платные (руб)

Расширение освободит вас от необходимости вручную обновлять товары в группах ВКонтакте. Достаточно задать правила один раз, и система автоматически синхронизирует ваш каталог. Вы сможете легко выбирать, какие товары публиковать, создавая гибкие критерии отбора. Например, можно добавить важные для покупателей параметры: цвет, размер или другие характеристики.

12200 руб.

29.08.2025    2260    7    6    

9

WEB-интеграция Программист Бизнес-аналитик 1С:Предприятие 8 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Оптовая торговля, дистрибуция, логистика ИТ-компания Платные (руб)

Модуль "Экспортер" — это расширение для 1С, предназначенное для автоматизации процессов выгрузки данных. Оно позволяет эффективно извлекать, преобразовывать и передавать данные из систем 1С в интеграционную платформу Spot2D. Подсистема упрощает настройку, снижает количество ручных операций и обеспечивает удобный контроль данных.

17568 руб.

20.12.2024    5778    25    4    

27
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. user-z99999 78 26.12.19 11:45 Сейчас в теме
sp_configure 'show advanced options', 1 
GO 
RECONFIGURE; 
GO 
sp_configure 'Ole Automation Procedures', 1 
GO 
RECONFIGURE; 
GO 
sp_configure 'show advanced options', 1 
GO 
RECONFIGURE;
GO 

Declare @ResponseText as nvarchar(max);
SET @ResponseText = dbo.HTTPRequest('zzz=yyy');
PRINT(@ResponseText);

Declare @ResponseText as nvarchar(max);
SET @ResponseText = dbo.HTTPRequest('СистемнаяИнформация = Новый СистемнаяИнформация; Результат = СистемнаяИнформация.ВерсияПриложения;');
PRINT(@ResponseText);
Показать


Ловлю
<!DO CTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<ht ml><head>
<title>403 Forbidden</title>
</head><body>
<h1>Forbidden</h1>
<p>You don't have permission to access this resource.</p>
</body></html>

что нужно сделать?
2. user-z99999 78 26.12.19 11:58 Сейчас в теме
(1)
В методе указать строку подключения, пароль и логин желательно английскими буквами
Exec @ResponseError = sp_OAMethod @Object, 'open', NULL, 'post',
    'http://localhost/<base>/hs/<rootUrl>/', 'false', '<user>', '<password>';
3. script 128 29.12.19 02:40 Сейчас в теме
Здравствуйте. Ну а хотя бы один практический пример из жизни можно?
4. par_62 30.12.19 18:51 Сейчас в теме
Пример из жизни.
Внешнее устройство добавляет записи в таблицу Sql. Необходимо отловить это событие и запросить из 1с данные. Данные легко получаются через ODBC. Постоянно делать запросы в фоновом задании накладно. Интересует только момент изменения.
vvic; acanta; +2 Ответить
5. yermak 51 12.08.24 10:27 Сейчас в теме
Этот подход очень не Ок, особенно если будет много добавлений в таблицу
6. vvic 08.08.25 07:17 Сейчас в теме
(5) Подскажите пожалуйста другой вариант реализации подобной задачи, если необходимо чтобы данные введенные в SQL таблицу legacy приложением необходимо получить в 1С в тот же момент?
Для отправки сообщения требуется регистрация/авторизация