Получение таблицы из Web-сервиса SAP в 1с

23.07.14

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

Решение проблемы с получением данных сложного типа в 1с из SAP

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

Проверка дополнительного свойства:
форма: Элемент
имя: NameItem: Ошибка преобразования данных XDTO:
Чтение объекта типа: {urn:sap-com:document:sap:soap:functions:mc-style}NameType
Проверка дополнительного свойства:
форма: Элемент
имя: item: Ошибка проверки данных XDTO:
Собственно проблему решили, причем 2мя способами:
1)     Самый простой вместо вызова web-сервиса,воспользовались post запросом. Примеров отправки POST-запроса много, ниже привожу рабочий код.
 

 ПроцедураОтправкаЗапроса()
     Сервер = //имя сервера
     Ресурс = // имя ресурса 
    
     HTTP =  Новый HTTPСоединение(Сервер,,,,,, Истина) ;
     Логин = //ваш логин
     Пароль = //ваш пароль
    
     СтрокаАвторизации = СтрокаВBase64(ВРег(Логин)+":"+Пароль);   
     ЗаголовокHTTP = Новый Соответствие();
     ЗаголовокHTTP.Вставить("Content-Type","text/xml");
     ЗаголовокHTTP.Вставить("Accept-Charset","utf-8");
     ЗаголовокHTTP.Вставить("Content-Charset","utf-8");
     ЗаголовокHTTP.Вставить("Authorization","Basic"+СтрокаАвторизации);
     СтрокаЗапрос = //текст вашего запроса. Если есть сложностьс составлением рекомендую для этого воспользоваться программой SOAPUI
     СтрокаЗапрос = СтрЗаменить(СтрокаЗапрос,Символы.ПС,"");
     ТекстДок = Новый ТекстовыйДокумент;
     ТекстДок.ВставитьСтроку(1,СтрокаЗапрос);
     ИмяФайлаЗапроса =ПолучитьИмяВременногоФайла(".txt");
     ТекстДок.Записать(ИмяФайлаЗапроса);
     ИмяФайлаОтвета =ПолучитьИмяВременногоФайла(".txt");
     HTTP.ОтправитьДляОбработки(ИмяФайлаЗапроса, Ресурс,ИмяФайлаОтвета, ЗаголовокHTTP);    
 КонецПроцедуры
 
 Функция СтрокаВBase64(Строка)    
     СтрокаBase64 = "";    
     ИмяВременногоФайла = ПолучитьИмяВременногоФайла();
     ЗаписьТекста = Новый ЗаписьТекста(ИмяВременногоФайла);
     ЗаписьТекста.Записать(Строка);
     ЗаписьТекста.Закрыть();
     СтрокаBase64 = Base64Строка(НовыйДвоичныеДанные(ИмяВременногоФайла));
     СтрокаBase64 =СтрЗаменить(СтрокаBase64,"77u/","");
     Попытка
         УдалитьФайлы(ИмяВременногоФайла)
     Исключение
         Сообщить("Неудалось удалитьфайл преобразования строки авторизации (Base64) -"""+ИмяВременногоФайла+"""",СтатусСообщения.Внимание);
     КонецПопытки;
    
     Возврат СтрокаBase64;
    
 Конецфункции

На выходе получаем xml с данными, разбираем, получаем данные.
2)     Воспользоваться форматом JSON– то есть преобразовывать сложные типы на стороне SAP в JSON и как строку отдавать в 1с.
В 1с уже эта строка без проблем переводится в более удобный тип данных.

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

SAP интеграция

Вы можете заказать платную адаптацию этой статьи под ваши задачи на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

См. также

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

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

42700 руб.

03.08.2020    24355    37    24    

28

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    6326    28    4    

30

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

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

24000 руб.

02.02.2021    23067    69    52    

43

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

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

12200 руб.

29.08.2025    2802    7    8    

8

Обмен с ГосИС WEB-интеграция Бухгалтер Пользователь 1С:Предприятие 8 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

5283 руб.

28.04.2016    101211    120    219    

368
Для отправки сообщения требуется регистрация/авторизация