Использование внешних веб­сервисов в 1С на примере загрузки курсов валют

04.12.12

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

С некоторых пор в 1С 8.х появилась возможность использования веб-сервисов: 1С может выступать как поставщиком, так и потребителем. В этой статье я покажу, как использовать 1С в качестве потребителя на примере получения курсов валют с сервера ЦБР.

Веб-сервис


У Центробанка существует веб-сервис для получения ежедневных данных: курсы валют, новости, динамика курсов и т.д. Описание сервиса можно найти здесь http://www.cbr.ru/scripts/Root.asp?Prtid=DWS. Нас интересует один из методов этого сервиса: GetCursOnDate(On_date) – получение курсов валют на заданную дату. В метод передается один аргумент On_date – это дата, на которую требуется получить курсы. В результате возвращается XML, содержащий таблицу ValuteCursOnDate (сами курсы и сопутствующая информация). 
 

Конфигурирование


Для разработки я взял 1С 8.2 (8.2.15.317 в моем случае) и создал пустую конфигурацию. Для использования внешних веб-сервисов предусмотрен объект WS-ссылки, но использовать его не обязательно, к сервису можно обращаться динамически из кода. Я буду использовать первый вариант, а затем покажу, как можно использовать второй. В конфигурации создал обработку и назвал ее «ЗагрузкаКурсовВалютЦБР». Добавил форму (управляемую) и сделал ее основной. На форме я создал реквизиты и разместил элементы управления так, как показано на рисунке.

 

 

Сейчас самое главное – создаем ссылку на описание веб-сервиса. В конфигурации добавляем новый объект типа WS-ссылка. В появившемся окне указываем ссылку на WSDL (описание данного формата выходит за рамки статьи, вы можете почитать о нем на Википедии): http://www.cbr.ru/DailyInfoWebServ/DailyInfo.asmx?WSDL.

1С на основании полученного описания автоматически создаст визуальную карту веб-сервиса. Можно увидеть название веб-сервиса, посмотреть какие у него доступны операции а так же используемые типы данных.

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

Эти настройки позволят нам отобразить форму обработки прямо на рабочем столе (имеется ввиду рабочий стол программы 1С) в режиме 1С Предприятие. 
 

Программирование


Теперь осталось наполнить смыслом нашу обработку: заставить ее получать курсы валют и отображать в таблице на форме. В режиме редактирования формы необходимо добавить новую команду формы, назовем ее ЗагрузитьВалюты. Эту команду необходимо связать с кнопкой, расположенной на форме. Действие для команды заполним следующим кодом (прим. автора: ничего себе, на хабре есть подсветка кода 1С, правда она работает не корректно):

&НаКлиенте
Процедура ЗагрузитьВалюты(Команда)
    Если НЕ ЗначениеЗаполнено(ДатаЗагрузки) Тогда 
        Сообщить("Не выбрана дата загрузки!", СтатусСообщения.Важное);
        Возврат;
    КонецЕсли;
    ТаблицаКурсовВалют.Очистить();
    ЗагрузитьКурсыВалют(ДатаЗагрузки);
КонецПроцедуры

Здесь сначала проверяется, заполнена ли дата (если не заполнена, то сообщаем об этом пользователю и больше ничего не делаем). Затем очищается таблица, расположенная на форме и вызывается процедура ЗагрузитьКурсыВалют(), в которую передается дата.

Код процедуры ЗагрузитьКурсыВалют(), пояснения даны в комментариях к коду:

Процедура ЗагрузитьКурсыВалют(фДатаЗагрузки)
    //Создаем прокси для обращения к внешнему веб-сервису,
    // передаем в функцию URI пространства имен, имя сервиса, имя порта.
    Прокси = WSСсылки.CBR_DailyInfoWebServ.СоздатьWSПрокси(
                                         "http://web.cbr.ru/", "DailyInfo", "DailyInfoSoap");
    
    //Получаем тип параметра, который передается в метод GetCursOnDate.
    ТипWSПараметра = Прокси.ФабрикаXDTO.Пакеты.Получить(
                                        "http://web.cbr.ru/").Получить("GetCursOnDate");
    //Создаем параметр на основе типа и заполняем значение параметра On_Date.
    WSПараметр  = Прокси.ФабрикаXDTO.Создать(ТипWSПараметра);
    WSПараметр.On_Date= фДатаЗагрузки;
    
    //Вызываем метод веб-сервиса, записываем результат в переменную КурсыВалют.
    КурсыВалют = Прокси.GetCursOnDate(WSПараметр);
    
    //Перебираем таблицу ValuteCursOnDate, каждое значение таблицы
    // добавляем в таблицу на форме (колонки заполняем соответствующими значениями).
    Для Каждого Элемент Из КурсыВалют.GetCursOnDateResult.diffgram.ValuteData.ValuteCursOnDate Цикл 
        НоваяСтрокаТЗ = ТаблицаКурсовВалют.Добавить();
        НоваяСтрокаТЗ.НазваниеВалюты      = Элемент.Vname;
        НоваяСтрокаТЗ.Номинал             = Элемент.Vnom;
        НоваяСтрокаТЗ.ЦифровойКодВалюты   = Элемент.Vcode;
        НоваяСтрокаТЗ.СимвольныйКодВалюты = Элемент.VChCode;
        НоваяСтрокаТЗ.КурсВалюты          = Элемент.Vcurs;
    КонецЦикла;
КонецПроцедуры

Теперь можно обновлять конфигурацию БД (F7) и запускать 1С Предприятие (F5). Если все сделали верно, то должны увидеть окно как на рисунке ниже:

Чтобы проверить результат, нам нужно ввести дату, на которую хотим получить курсы валют и нажать на кнопку «Загрузить валюты». В случае успешного запроса, таблица на форме заполнится значениями курсов:

Напоследок хочу показать, как можно обратиться динамически к внешнему веб-сервису, то есть без добавления объекта WS-ссылка. Таким образом, мы можем использовать такие веб-сервисы из внешних обработок без привязки к конфигурации.

В процедуре ЗагрузитьКурсыВалют() строку

Прокси = WSСсылки.CBR_DailyInfoWebServ.СоздатьWSПрокси("http://web.cbr.ru/", "DailyInfo", "DailyInfoSoap");

необходимо заменить двумя следующими строками

Определения = Новый WSОпределения("http://www.cbr.ru/DailyInfoWebServ/DailyInfo.asmx?WSDL");
Прокси = Новый WSПрокси(Определения, "http://web.cbr.ru/", "DailyInfo", "DailyInfoSoap");

Сначала мы создаем так называемые определения для веб-сервиса из его WSDL. Затем так же создаем прокси для обращения к нему.

Как видно, использовать внешние веб-сервисы из 1С в целом довольно просто (хотя и есть некоторая сложность в понимании определения типов, у меня в том числе).

Если данная публикация найдет здесь отклик, то есть еще несколько тем, о которых можно рассказать. 

По ссылке можно скачать конфигурацию с примером (cf-файл).

 

Впервые опубликовано на habrahabr.ru

См. также

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

Функциональное решение для торговли на всех популярных маркетплейсах. Работает со схемами FBO и FBS. Простое в использовании и установке, не вносит изменения в код программы. Существенно упрощает работу с товарным ассортиментом, обработку заказов с площадок, работу с поставками, а также ведение аналитики по продажам и остаткам.

72000 руб.

19.07.2024    1096    52    0    

3

Управление взаимоотношениями с клиентами (CRM) WEB-интеграция Анализ продаж Системный администратор Программист Пользователь Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Управленческий учет Платные (руб)

Подсистема интеграции Amo CRM с 1С: технические требования, порядок работы, возможности, доработки и обновления. Бесплатный период техподдержки - 1 месяц.

60000 руб.

07.05.2019    32878    62    41    

23

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

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

12000 руб.

02.02.2021    17537    47    50    

28

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

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

22656 руб.

25.05.2021    13916    39    8    

15

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

Универсальное расширение конфигурации для автоматической загрузки и заполнения реквизитов контрагентов (партнеров) из ОГРН для 1С:ERP Управление предприятием 2 (1С:ERP Управление предприятием 2, редакция 2.4), 1С:ERP Управление предприятием 2 (1С:ERP Управление предприятием 2, редакция 2.2), 1С:Управление торговлей 8 (Управление торговлей, редакция 11.5), 1С:Управление торговлей 8 (Управление торговлей, редакция 11.4), 1С:Управление торговлей 8 (Управление торговлей, редакция 11.3), 1С:Управление торговлей 8 (Управление торговлей, редакция 11.2), 1С:Комплексная автоматизация 8 (1С:Комплексная автоматизация, редакция 2.4), 1С:Комплексная автоматизация 8 (1С:Комплексная автоматизация, редакция 2.2), 1С:Комплексная автоматизация 8 (1С:Комплексная автоматизация, редакция 2.0) и 1С:Бухгалтерия 8 (Бухгалтерия предприятия, редакция 3.0).

3900 руб.

08.11.2017    62448    402    295    

71
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. ardn 647 04.12.12 12:45 Сейчас в теме
Интересно было бы узнать, как соединить 1С с сайтами с REST API с аутентификацией
2. mix 90 04.12.12 13:00 Сейчас в теме
(1) насколько я помню, на ИТС есть заметка об использовании REST-сервисов.
3. mix 90 04.12.12 13:01 Сейчас в теме
Подскажите, как раскрасить код в статье?
4. necropunk 9 05.12.12 14:47 Сейчас в теме
Просто, понятно, новичкам сгодится. Про раскрашивание вот тут http://infostart.ru/public/66592/ в пятом пункте рекомендуют воспользоваться этим http://infostart.ru/public/19856/ или вот этим http://infostart.ru/public/62249/
5. mkostya 30 05.12.12 20:58 Сейчас в теме
таких примеров уже штук пять точно предлагаю сделать наоборот.
Веб сервис по выдаче инофрмации.
Например, сервис по проверке задолженности контрагента путем ввода ИНН используя данные БД. На сайте вводим ИНН и 1С нам отвечает, долгов по Вам нету или сумма задолженности если она есть.
9. Yashazz 4773 06.12.12 13:35 Сейчас в теме
Да уж, очередной баян.
Согласен с (5), вы лучше примерчик 1С-провайдера сделайте.
6. CagoBHuK 32 06.12.12 09:55 Сейчас в теме
А чем не нравится статься про аэропорт?
7. mix 90 06.12.12 10:02 Сейчас в теме
(6) CagoBHuK, там веб-сервис давно не рабочий.
8. CagoBHuK 32 06.12.12 10:09 Сейчас в теме
(7) Дело не в работе веб-сервиса, а в понимании основных принципов. Вообще, прежде, чем пытаться что-то сделать, нужно ознакомиться с первоисточниками. Хотя бы тут: http://www.w3.org/TR/soap/ После этого не нужен будет живой веб-сервис для написания нескольких строчек кода.
10. SlavaK 27.11.15 17:15 Сейчас в теме
Спасибо за простой пример!
11. vgrichuk 10.11.16 17:26 Сейчас в теме
ЦБ перестал отдавать этот вебсервис по http, только по https. Для исправления надо сделать в коде небольшие изменения:
ssl1 = Новый ЗащищенноеСоединениеOpenSSL();
Определения = Новый WSОпределения("https://www.cbr.ru/DailyInfoWebServ/DailyInfo.asmx?WSDL",,,,,ssl1);
Прокси = Новый WSПрокси(Определения,"http://web.cbr.ru/","DailyInfo","DailyInfoSoap",,,ssl1);

далее всё по-старому
12. garikxxx 21.11.16 01:15 Сейчас в теме
(11) vgrichuk,
есть немного другая задача и никак не могу решить ее, был бы очень признателен за помощь
13. user642695_crocus.vladikina 29.04.19 15:43 Сейчас в теме
(11) а, вот в чем дело ! понятно
{Обработка.ЗагрузкаКурсовВалютЦБР.Форма.Форма.Форма(18)}: Метод объекта не обнаружен (СоздатьWSПрокси)
Прокси = метаданные.WSСсылки.WSLink.СоздатьWSПрокси("http://web.cbr.ru/", "DailyInfo", "DailyInfo");
14. user642695_crocus.vladikina 29.04.19 15:44 Сейчас в теме
ваш пример не рабочий с прокси. поэтому ?
15. ErrorEd88 54 21.03.22 15:22 Сейчас в теме
а как сделать отбор, чтобы только определенную валюту загружать и не перебирать в цикле?
user1508952; +1 Ответить
20. user832283 27.10.22 10:31 Сейчас в теме
(15) Метод GetCursDynamic http://www.cbr.ru/DailyInfoWebServ/DailyInfo.asmx
Соответствие между кодами валют ОКР и кодами ЦБ РФ в методе EnumValutes
ErrorEd88; +1 Ответить
21. Xershi 1519 07.03.24 17:40 Сейчас в теме
(20) увы метод корявый. Пришлось отказаться. В моей логике курс должен быть на каждую дату. А по выходным этот метод ничего не отдает.
МестоположениеWSDL = "http://www.cbr.ru/DailyInfoWebServ/DailyInfo.asmx?WSDL";

WSОпределение = Новый WSОпределения(МестоположениеWSDL);

ПространствоИмен = "http://web.cbr.ru/";

//Создаем прокси для обращения к внешнему веб-сервису,
// передаем в функцию URI пространства имен, имя сервиса, имя порта.
Прокси = Новый WSПрокси(WSОпределение, ПространствоИмен, "DailyInfo", "DailyInfoSoap");

//Получаем тип параметра, который передается в метод GetCursOnDate.
ТипWSПараметра = Прокси.ФабрикаXDTO.Пакеты.Получить(ПространствоИмен).Получить("GetCursOnDate");
//ТипWSПараметра = Прокси.ФабрикаXDTO.Пакеты.Получить(ПространствоИмен).Получить("GetCursDynamic");

//Создаем параметр на основе типа и заполняем значение параметра On_Date.
WSПараметр = Прокси.ФабрикаXDTO.Создать(ТипWSПараметра);

// Параметры GetCursOnDate
WSПараметр.On_Date = ДатаКурса;

// Параметры GetCursDynamic
//WSПараметр.FromDate		= ДатаКурса;
//WSПараметр.ToDate		= ДатаКурса;
//WSПараметр.ValutaCode	= Строка.СимвольныйКод;

//Вызываем метод веб-сервиса, записываем результат в переменную КурсыВалют.
КурсыВалютЦБРФ = Прокси.GetCursOnDate(WSПараметр);
//КурсыВалютЦБРФ = Прокси.GetCursDynamic(WSПараметр);

ТаблицаКурсыВалютЦБРФ = КурсыВалютЦБРФ.GetCursOnDateResult.diffgram.ValuteData.ValuteCursOnDate;
// Падает, т.к. нету данныех на выходные!
//КурсВалютЦБРФ = КурсыВалютЦБРФ.GetCursDynamicResult.diffgram.ValuteData.ValuteCursDynamic;

НайденаВалютаЦБРФ = Ложь;

КурсВалютыЦБРФ = 0;
КратностьВалютыЦБРФ = 0;

Для Каждого СтрокаКурсовЦБРФ Из ТаблицаКурсыВалютЦБРФ Цикл
	
	Если СтрокаКурсовЦБРФ.VchCode = КодВалютыЦБРФ Тогда
		
		НайденаВалютаЦБРФ	= Истина;
		КурсВалютыЦБРФ		= СтрокаКурсовЦБРФ.Vcurs;
		КратностьВалютыЦБРФ	= СтрокаКурсовЦБРФ.Vnom;
		Прервать;
		
	КонецЕсли;
	
КонецЦикла;

//Если ТипЗнч(КурсВалютЦБРФ) = Тип("ОбъектXDTO") Тогда
//	
//	НайденаВалютаЦБРФ	= Истина;
//	КурсВалютыЦБРФ		= КурсВалютЦБРФ.Vcurs;
//	КратностьВалютыЦБРФ	= КурсВалютЦБРФ.Vnom;
//	
//КонецЕсли;

Если НайденаВалютаЦБРФ Тогда
	
	КурсВалютыНаДату.Cur_Name			= Строка.Представление;
	КурсВалютыНаДату.Cur_OfficialRate	= КурсВалютыНаДату.Cur_Scale / (Число(СокрЛП(КурсВалютыЦБРФ)) * Число(СокрЛП(КратностьВалютыЦБРФ)));
	
	ЗагрузитьКурсыВалютВРегистр(КурсВалютыНаДату, ТекстСообщения, Ложь);
	
Иначе
	
	ТекстСообщения = "Не удалось получить курс ЦБРФ по отношению к " + Строка.Представление + " на " + Формат(ДатаКурса, "ДЛФ=DD") + "!";
	
КонецЕсли;
Показать

Плюс для него еще нужно хранить в 1С ИД валюты, который к классификатору и человекочитаемым значениям никакого отношения не имеет.
16. пользователь 13.06.22 23:07
Сообщение было скрыто модератором.
...
17. пользователь 13.06.22 23:35
Сообщение было скрыто модератором.
...
18. пользователь 13.06.22 23:45
Сообщение было скрыто модератором.
...
19. пользователь 15.06.22 07:17
Сообщение было скрыто модератором.
...
Оставьте свое сообщение