Рыба моей WSDL. Генератор кода для обращения к web-сервису

12.01.23

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

Обработка создаёт заготовку кода на языке 1С для обращения к Web-сервису на основании данных страницы WSDL.

Скачать исходный код

Наименование Файл Версия Размер
РыбаWSDL-уф
.epf 10,61Kb
13
.epf 1 10,61Kb 13 Скачать
РыбаWSDL-оф
.epf 11,40Kb
6
.epf 1 11,40Kb 6 Скачать
Рыба моей WSDL-уф, версия 1.2
.epf 12,26Kb
6
.epf 1.2 12,26Kb 6 Скачать

Ох и намучался я с web-сервисом! Тут тебе и заклинания с WS-определением, фабрика XDTO, экзотические структуры, вложенные друг в друга типы, обязательные поля, необязательные...

А когда на одном сайте есть несколько точек подключения, да на каждой свои сервисы, да на каждой свое пространство имён!  Голова кругом идёт.

И казалось бы: у web-сервиса есть страничка WSDL, которая описывает все особенности. Но вручную разбирать все эти описания - врагу не пожелаешь.

Чтобы поучиться, хорошо было бы найти какой-нибудь работающий пример. Но что-то всё разом отказывалось работать. А код на языке 1С и вовсе не хотел находиться.

 

Разобрался с одним сервисом, написал работающий код. Но функционал сервиса не подошёл. Нужно писать код для другого. "Всего-то?" - скажете Вы. Увы! Вот здесь-то самая большая путаница: какие из функций к какому сервису относятся? Какие пространства имён в каждом случае должны применяться? Какие параметры?

В описании сервиса много информации, но всё однотипное, всё похожее. И никакой гарантии, что "человеческий фактор" не напутал чего.

Хочется перепробовать все сервисы, найти наиболее подходящий. Но для каждого требуется писать свой код.

Вот бы на каждый случай предоставлялась своя "рыба", заготовка кода, где достаточно вставить требуемые значения и удалить неиспользумые сроки!

Где ты, рыба моей мечты? 

 

А вот она! Вашему вниманию предлагается обработка, генерирующая заготовки для кода. Как кода для вызова, так и для кода разбора ответа сервиса.

Всё просто и очевидно: в поле "Адрес веб сервиса" вносите ссылку ...?wsdl, а далее выбираете из списков подходящие параметры. Там, где выбор есть.

И нажимаете на кнопку "Сформировать WSТекст". Получаете "рыбу", где требуется вставить нужные параметры на входе, проанализировать полученные данные на выходе.

 

 

В качестве примера предлагаю:

https://www.dataaccess.com/webservicesserver/numberconversion.wso?WSDL

http://webservices.oorsprong.org/websamples.countryinfo/CountryInfoService.wso?WSDL

Например, обращение к https://www.dataaccess.com/webservicesserver/numberconversion.wso?WSDL , операция NumberToWords даёт код:

 

Попытка
    Определения = Новый WSОпределения("https://www.dataaccess.com/webservicesserver/numberconversion.wso?WSDL"); //,Логин,Пароль); 
Исключение
    Определения = Неопределено;
КонецПопытки;
Если НЕ Определения = Неопределено Тогда 
    Попытка
        Прокси = Новый WSПрокси(Определения,"http://www.dataaccess.com/webservicesserver/", "NumberConversion", "NumberConversionSoap");
    Исключение
        Прокси = Неопределено;
    КонецПопытки;
КонецЕсли;
	
ubiNum = ... Значения типа unsignedLong;
ОтветСервиса = Прокси.NumberToWords(ubiNum);
Сообщить(ОтветСервиса);
// ... Значения типа string


Чтобы сделать его рабочим, нужно заменить всего одну строку: "ubiNum = ... Значения типа unsignedLong;" поменяем на "ubiNum = 123456;". Его исполнение выведет на экран ответ сервиса: "one hundred and twenty three thousand four hundred and fifty six"

 

А для "http://webservices.oorsprong.org/websamples.countryinfo/CountryInfoService.wso?WSDL", операция "ListOfCountryNamesGroupedByContinent" будет сгенерирован код:

 

Попытка
    Определения = Новый WSОпределения("http://webservices.oorsprong.org/websamples.countryinfo/CountryInfoService.wso?WSDL"); //,Логин,Пароль); 
Исключение
    Определения = Неопределено;
КонецПопытки;
Если НЕ Определения = Неопределено Тогда 
    Попытка
        Прокси = Новый WSПрокси(Определения,"http://www.oorsprong.org/websamples.countryinfo", "CountryInfoService", "CountryInfoServiceSoap");
    Исключение
        Прокси = Неопределено;
    КонецПопытки;
КонецЕсли;
	
ОтветСервиса = Прокси.ListOfCountryNamesGroupedByContinent();
Сообщить(ОтветСервиса);
// ... Значения типа ArrayOftCountryCodeAndNameGroupedByContinent
ВГраница1 = ОтветСервиса.tCountryCodeAndNameGroupedByContinent.Количество() - 1;
Для Н1 = 0 По ВГраница1 Цикл //Начало цикла по tCountryCodeAndNameGroupedByContinent
sCode = ОтветСервиса.tCountryCodeAndNameGroupedByContinent[Н1].Continent.sCode; // Тип = string
sName = ОтветСервиса.tCountryCodeAndNameGroupedByContinent[Н1].Continent.sName; // Тип = string
ВГраница3 = ОтветСервиса.tCountryCodeAndNameGroupedByContinent[Н1].CountryCodeAndNames.tCountryCodeAndName.Количество() - 1;
Для Н3 = 0 По ВГраница3 Цикл //Начало цикла по tCountryCodeAndName
sISOCode = ОтветСервиса.tCountryCodeAndNameGroupedByContinent[Н1].CountryCodeAndNames.tCountryCodeAndName[Н3].sISOCode; // Тип = string
snamf = ОтветСервиса.tCountryCodeAndNameGroupedByContinent[Н1].CountryCodeAndNames.tCountryCodeAndName[Н3].sName; // Тип = string
КонецЦикла;//Конец цикла по tCountryCodeAndName
КонецЦикла;//Конец цикла по tCountryCodeAndNameGroupedByContinent

Код уже рабочий. Но чтобы извлечь из него хоть какую-то пользу, добавим пару строк "Сообщить...":

Попытка
    Определения = Новый WSОпределения("http://webservices.oorsprong.org/websamples.countryinfo/CountryInfoService.wso?WSDL"); //,Логин,Пароль); 
Исключение
    Определения = Неопределено;
КонецПопытки;
Если НЕ Определения = Неопределено Тогда 
    Попытка
        Прокси = Новый WSПрокси(Определения,"http://www.oorsprong.org/websamples.countryinfo", "CountryInfoService", "CountryInfoServiceSoap");
    Исключение
        Прокси = Неопределено;
    КонецПопытки;
КонецЕсли;
	
ОтветСервиса = Прокси.ListOfCountryNamesGroupedByContinent();
Сообщить(ОтветСервиса);
// ... Значения типа ArrayOftCountryCodeAndNameGroupedByContinent
ВГраница1 = ОтветСервиса.tCountryCodeAndNameGroupedByContinent.Количество() - 1;
Для Н1 = 0 По ВГраница1 Цикл //Начало цикла по tCountryCodeAndNameGroupedByContinent
sCode = ОтветСервиса.tCountryCodeAndNameGroupedByContinent[Н1].Continent.sCode; // Тип = string
sName = ОтветСервиса.tCountryCodeAndNameGroupedByContinent[Н1].Continent.sName; // Тип = string
ВГраница3 = ОтветСервиса.tCountryCodeAndNameGroupedByContinent[Н1].CountryCodeAndNames.tCountryCodeAndName.Количество() - 1;

Сообщить(""+Н1+" : "+sCode+"," + sName);

Для Н3 = 0 По ВГраница3 Цикл //Начало цикла по tCountryCodeAndName
sISOCode = ОтветСервиса.tCountryCodeAndNameGroupedByContinent[Н1].CountryCodeAndNames.tCountryCodeAndName[Н3].sISOCode; // Тип = string
snamf = ОтветСервиса.tCountryCodeAndNameGroupedByContinent[Н1].CountryCodeAndNames.tCountryCodeAndName[Н3].sName; // Тип = string

Сообщить("  "+Н3+" : "+sISOCode+"," + snamf);

КонецЦикла;//Конец цикла по tCountryCodeAndName
КонецЦикла;//Конец цикла по tCountryCodeAndNameGroupedByContinent

А вот, скажем, обращение к http://ws.dpd.ru:80/services/order2?wsdl, операция "createOrder" создаст "рыбу" из 195-и строк кода. 

Обращение с помощью протокола SOAP наглядно, когда можно посмотреть файл XML. И ответ сервера.

Для этого можно воспользоваться второй кнопкой "Сформировать HTTPТекст". Для случая и операции NumberToWords получаем текст:

аписьXML = Новый ЗаписьXML;
ЗаписьXML.УстановитьСтроку();

ЗаписьXML.ЗаписатьНачалоЭлемента("soap:Envelope");
ЗаписьXML.ЗаписатьАтрибут("xmlns:soap", "http://schemas.xmlsoap.org/soap/envelope/");
ЗаписьXML.ЗаписатьАтрибут("xmlns:ns0", "http://www.dataaccess.com/webservicesserver/");

ЗаписьXML.ЗаписатьНачалоЭлемента("soap:Header");
ЗаписьXML.ЗаписатьКонецЭлемента();

ЗаписьXML.ЗаписатьНачалоЭлемента("soap:Body");

ЗаписьXML.ЗаписатьНачалоЭлемента("ns0:NumberToWords");
ЗаписьXML.ЗаписатьАтрибут("xmlns:xs", "http://www.w3.org/2001/XMLSchema");
ЗаписьXML.ЗаписатьАтрибут("xmlns:xsi", "http://www.w3.org/2001/XMLSchema-instance");

ЗаписьXML.ЗаписатьНачалоЭлемента("ubiNum");
ЗаписьXML.ЗаписатьТекст("...");
ЗаписьXML.ЗаписатьКонецЭлемента();
ЗаписьXML.ЗаписатьКонецЭлемента();
ЗаписьXML.ЗаписатьКонецЭлемента();
ЗаписьXML.ЗаписатьКонецЭлемента();
ТекстXML = ЗаписьXML.Закрыть();

Сообщить(ТекстXML);
Таймаут=10000;
URL ="https://www.dataaccess.com/webservicesserver/numberconversion.wso?WSDL";
WinHttp = Новый COMОбъект("WinHttp.WinHttpRequest.5.1");
WinHttp.SetTimeouts(Таймаут, Таймаут, Таймаут, Таймаут);

WinHttp.Option(2,"utf-8");
WinHttp.Open("POST",URL);

WinHttp.setRequestHeader("Content-Type","text/xml; charset=utf-8");

Сообщить("Начало - " + ТекущаяДата());
Сообщить("URL: " + URL);
Попытка
	WinHttp.Send(ТекстXML);
	Сообщить("Завершение - " + ТекущаяДата());
	Если WinHttp.Status = 200 Тогда
		Сообщить("Ответ: " + WinHttp.ResponseText);
	 Иначе
		Сообщить("Ошибка сервера: " + WinHttp.Status + " " + WinHttp.ResponseText + " " + WinHttp.StatusText, СтатусСообщения.Важное);
	КонецЕсли;
Исключение
	Сообщить("Ошибка запроса по HTTP");
	Сообщить(ОписаниеОшибки(), СтатусСообщения.Важное);
КонецПопытки;

Пример файла-запроса и файла ответа приведён ниже:

 

файл запроса через httpфайл ответа по http

 

Обработки тестировались на релизе 8.3.14.1779.

WSDL SOAP. Web-сервис генератор кода конструктор мастер волшебник wizard рыба

См. также

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

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

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

36000 руб.

03.08.2020    15933    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    17888    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    88943    163    216    

318

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

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

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

8400 руб.

01.02.2019    25873    9    0    

7

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

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

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

12000 руб.

02.02.2021    16479    42    49    

23
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. alekseineputin 25 30.09.21 10:28 Сейчас в теме
За песенку креативненько :)

+
2. starik-2005 3036 30.09.21 11:10 Сейчас в теме
А порт куда совать?
+
3. Sure 163 30.09.21 12:39 Сейчас в теме
(2) Порт? Ну так он в адресной строке. Там и остаётся.https://disk.yandex.ru/i/UevXB0FJM_q9UA
+
4. starik-2005 3036 30.09.21 13:02 Сейчас в теме
(3)
Там и остаётся.https://disk.yandex.ru:XXXX/i/UevXB0FJM_q9UA
+
5. Sure 163 20.10.21 22:21 Сейчас в теме
Кстати, вот обработка коллеги "Интеграция с API Boxberry": с помощью HTTP, JSON.
Поскольку Boxberry предлагает как интеграцию с помощью JSON, так и с помощью SOAP, то можете сравнить возможности и удобства
haland; +1
6. troy66 08.11.21 08:18 Сейчас в теме
Если требуется Аутентификация пользователя. Как ввести Логин и пароль?
+
7. Sure 163 10.11.21 09:30 Сейчас в теме
(6)
Если требуется Аутентификация пользователя. Как ввести Логин и пароль?

Это только по месту напильником: в коде я предусмотрел заготовку для вставки логина и пароля на при получении определения

Попытка
    Определения = Новый WSОпределения("http://ws.dpd.ru:80/services/tracing1-1?wsdl"); //,Логин,Пароль); 
Исключение
    Определения = Неопределено;
КонецПопытки;

Получится что-то вроде:
    Определения = Новый WSОпределения("http://ws.dpd.ru:80/services/tracing1-1?wsdl",Логин,Пароль); 


В передаваемых данных, разумеется, предполагается аутентификация. Что-то вроде

auth = Прокси.ФабрикаXDTO.Создать(Тип_auth);
auth.clientNumber = ... Значения типа long;
auth.clientKey = ... Значения типа string;
request.auth = auth;

А уж при обращении через http всякие логины-пароли-токены могут потребоваться в самое неожиданное время...
+
8. rokhin 143 14.11.23 13:12 Сейчас в теме
(7)
Получится что-то вроде:
Определения = Новый WSОпределения("http://ws.dpd.ru:80/services/tracing1-1?wsdl",Логин,Пароль);



И ещё требуется

    Попытка
        Прокси = Новый WSПрокси(Определения,URIПространстваИменВебСервиса, ИмяВебСервиса, ИмяТочкиПодключения);
	Прокси.Пользователь = Логин;
	Прокси.Пароль = Пароль;
    Исключение
        Прокси = Неопределено;
    КонецПопытки;


А это не требуется :

(7)
В передаваемых данных, разумеется, предполагается аутентификация. Что-то вроде
Sure; +1
9. rokhin 143 14.11.23 13:29 Сейчас в теме
в обработке просто добавить на 272 строке:

	|    	Прокси.Пользователь = Логин;
    |		Прокси.Пароль = Пароль;
+
10. user2003345 23.11.23 18:02 Сейчас в теме
Как передать параметр, допустим название страны, чтобы получить его ISO код? это я про http://webservices.oorsprong.org/websamples.countryinfo/CountryInfoService.wso?WSDL
Чтобы я не делал, возвращается ошибка 500. например, при использовании метода CountryISOCode там параметр sCountryName
+
11. Sure 163 24.11.23 16:57 Сейчас в теме
Если запустить обработку и скормить ей адрес http://webservices.oorsprong.org/websamples.countryinfo/CountryInfoService.wso?WSDL , то можно получить код:
Попытка
    Определения = Новый WSОпределения("http://webservices.oorsprong.org/websamples.countryinfo/CountryInfoService.wso?WSDL"); //WSОпределение = ?(ЗащищенноеСоединение, Новый WSОпределения(АдресВебСервиса,Логин,Пароль,ИнтернетПрокси,Таймаут,Новый ЗащищенноеСоединениеOpenSSL), Новый WSОпределения(АдресВебСервиса,Логин,Пароль));
Исключение
    Определения = Неопределено;
КонецПопытки;
Если НЕ Определения = Неопределено Тогда 
    Попытка
        Прокси = Новый WSПрокси(Определения,"http://www.oorsprong.org/websamples.countryinfo", "CountryInfoService", "CountryInfoServiceSoap");
    Исключение
        Прокси = Неопределено;
    КонецПопытки;
КонецЕсли;
	
sCountryName = "Russia";
//---------------------^^^^^^^^^ - передаём параметр

Попытка
  ОтветСервиса = Прокси.CountryISOCode(sCountryName);
  Отказ = Ложь;
Исключение
  Отказ = Истина;
  Сообщить("Сервис выдал ошибку при обращении к CountryISOCode : " + ОписаниеОшибки());
КонецПопытки;

Если Не Отказ Тогда

Сообщить(ОтветСервиса);
//^^^^^^^^^^^^^^^^^^^^^^^^^ -- показываем ответ
КонецЕсли;
Показать

Здесь уже две строки "доработаны по месту"
Строку
sCountryName = ... Значения типа string;

заменяем на
sCountryName = "Russia";

А строку
// ... Значения типа string

заменяем на
Сообщить(ОтветСервиса);


Код успешно выдаёт сообщение "RU".
+
Оставьте свое сообщение