Как создать веб-сервисы при помощи расширений 1С

В этой статье рассмотрим, как можно реализовать веб-сервис в расширении платформы 1С.

В качестве примера возьмем веб-сервис, позволяющий передавать информацию о клиентах из внешней CRM-системы во внутреннюю систему управленческого учета на «1С:Управление нашей фирмой».

Веб-сервис будет создан в расширении, чтобы сохранить конфигурацию на поддержке.

О чем эта статья

Материал статьи раскроет ответы на следующие вопросы:

  • Как работать с XDTO-пакетами?
  • Как создать веб-сервис и настроить его свойства?
  • Как опубликовать веб-сервис на сервере?

Постановка задачи

Компания ведет учет в типовом решении фирмы «1С:Управление нашей фирмой» (УНФ). Для управления взаимоотношениями с клиентами используется облачная CRM-система. В CRM-систему вводят информацию о новых клиентах. Необходимо реализовать перенос сведений о новых клиентах в УНФ сразу же при регистрации данных в CRM-системе.

Схема работы

Рисунок 1. Схема работы

Данные должны передаваться одним параметром (структурой). Спецификация данных, передаваемые из CRM в УНФ приведены в таблице 1.

Таблица 1. Требования к данным для обмена

Данные Имя cвойства Тип Ограничения
Полное наименование FullName Строка Обязательно для заполнения
ИНН INN Строка(12) Для ЮрЛица – длина 10
Для ИП – длина 12
Для ФизЛица – не заполняется
Допускаются только цифры
КПП KPP Строка(9) Для ЮрЛица – длина 9
Для ФизЛица – не заполняется
Допускаются только цифры
Телефон Phone Строка(12) Обязателен для заполнения
формат +7 (NNN) NNN-NN-NN

После создания контрагента в CRM-систему должен быть передан уникальный идентификатор. Идентификатор будет использоваться в дальнейшем для сопоставлении клиента в CRM и УНФ при обмене заказами. Необходимо реализовать описанный функционал без снятия УНФ с поддержки.

Обоснование выбора варианта решения

  1. Проанализируем требования. Добавлять клиентов надо «на лету», сразу же при вводе в CRM. Значит периодические обмены по расписанию нам не подходят.
  2. Выбранная CRM расположена в облаке, поэтому использовать COM-соединение не получится.
  3. В требованиях к передаваемым данным есть ограничения — на длину строк и на виды контрагентов. Выбирая между технологией обмена через http-сервисы и веб-сервисы, остановимся на веб-сервисах, так как типизация данных и настройка ограничений в них есть «из коробки». Дополнительным плюсом будет то, что веб-сервисы умеют «самодокументироваться», а значит мы экономим время на описании API для разработчиков CRM.
  4. Последнее требование — не снимать конфигурацию с поддержки.

Таким образом, для решения описанной задачи мы создадим расширение конфигурации. А в этом расширении реализуем веб-сервис для добавления информации о контрагентах.

Добавляем расширение

Начнем реализацию поставленной задачи и создадим новое расширение. Для этого откроем меню Конфигурация -> Расширения конфигурации.

Добавляем расширение

Рисунок 2. Добавляем расширение

В открывшемся окне жмем кнопку Добавить, а затем заполняем окно создания расширения.

Свойства нового расширения

Рисунок 3. Заполняем свойства нового расширения 

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

Импортируем объекты метаданных

Теперь импортируем в расширение объекты для дальнейшей работы. Нам нужны:

  • Справочник Контрагенты
  • Справочник Виды контактной информации
  • Перечисление Типы контактной информации

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

Импортируем справочник

Рисунок 4. Импортируем справочник

Затем добавим в расширение реквизиты справочника Контрагенты и табличную часть КонтактнаяИнформация.

В результате ветка Контрагенты в расширении должна выглядеть так:

Справочник «Контрагенты» в расширении

Рисунок 5. Справочник «Контрагенты» в расширении

После чего добавим в расширение перечисления ВидыКонтрагентов и ТипыКонтактнойИнформации.

Идем дальше. Из справочника ВидыКонтактнойИнформации нам нужно предопределенное значение ТелефонКонтрагента. Выдяем в дереве метаданных справочник ВидыКонтактнойИнформации и переходим по гиперссылке Предопределенные:

Предопределенные элементы справочника

Рисунок 6. Предопределенные элементы справочника

В ветке Контрагенты находим предопределенный элемент ТелефонКонтрагента.

Выбираем предопределенный элемент ТелефонКонтрагента

Рисунок 7. Выбираем предопределенный элемент ТелефонКонтрагента

Выполняем команду контекстного меню Добавить в расширение. В расширение добавляется справочник ВидыКонтактнойИнформации и его предопределенный элемент ТелефонКонтрагента.

Справочник «Виды контактной информации»

Элементы справочника «Виды контактной информации»

Рисунок 8. Справочник «Виды контактной информации» в расширении

С импортом объектов в расширение мы закончили. Теперь переходим к разработке веб-сервиса.

Как работают веб-сервисы

Веб-сервисы в 1C представляют собой реализацию протокола SOAP (от англ. Simple Object Access Protocol — простой протокол доступа к объектам). Архитектуру приложения на основе протокола SOAP можно представить в виде следующей схемы:

Архитектура приложений на основе протокола SOAP

Рисунок 9. Архитектура приложений на основе протокола SOAP

Общий принцип работы веб-сервиса можно описать так: мы создаем некий функционал, чтобы предоставить его сторонним разработчикам. Для того, чтобы этот функционал был им доступен, мы размещаем его на веб-сервере (публикуем). При публикации веб-сервиса происходит размещение его описания в формате WSDL (WSDL – Web Service Definition Language). Это описание стандартизовано и содержит описание методов веб-сервиса и типов данных, которые могут передаваться между сервисом и его клиентом. Клиент сервиса получает описание сервиса в виде WSDL-файла и может начать обмениваться данными в соответствии с этим описанием. Обмен происходит по протоколу HTTP, а сообщения передаются в теле HTTP пакетов в формате XML.

Особенность этой технологии состоит в том, что нам не нужно формировать XML и HTTP-пакеты вручную. Современные среды разработки, в том числе и 1С, позволяют работать с веб-сервисами в объектной технике.

Создаем XDTO-пакет

XDTO-пакеты описывают типы данных, которые будут использоваться при обмене. Потребителями веб-сервисов могут быть программы, написанные на разных языках, поэтому веб-сервис должен представить свои данные в виде примитивных типов (их описание во всех языках равнозначно). XDTO-пакеты позволяют привести типы 1С к типам, которые описаны в общемировом стандарте W3C. Кроме того, мы можем описать набор ограничений, применяемых к данным.

Приступаем к созданию XDTO-пакета для нашего веб-сервиса. В дереве метаданных расширения в ветке Общие -> XDTO-пакеты добавим XDTO-пакет ak_Customers. В URI пространства имен указываем http://kursy-po-1c.ru/ws/wsextension.

Это не ссылка на реальный адрес в интернете, а просто строка-идентификатор пространства имен, который помогает однозначно идентифицировать типы данных с одинаковыми именами. Например, программист Иванов определил тип данных Customer c двумя свойствами Name и FullName, а программист Петров определил свой тип Customer со свойствами Name, INN, KPP.

Чтобы не возникало путаницы и проблем с одинаковыми названиями типов, применяются пространства имен. Пространство имен и имя типа должны однозначно идентифицировать тип данных. При описании типов данных для веб-сервисов принято в качестве пространства имен использовать URI, содержащие доменное имя разработчика. Это позволяет сделать пространство имен уникальным.

Свойства XDTO-пакета

Рисунок 10. Свойства XDTO-пакета

Теперь жмем ссылку Открыть пакет и начинаем описывать типы данных.

Сначала опишем простые типы данных по которым нам нужно наложить ограничения. Это ИНН, КПП, Телефон.

ИНН по условиям задачи различается для ИП и для ЮрЛица.

Определим 2 простых типа: INN_IP и INN_UL. Для этого в форме редактирования пакета открываем меню Добавить -> ТипЗначения.

Добавляем тип значения в XDTO-пакет

Рисунок 11. Добавляем тип значения в XDTO-пакет

Заполняем свойства как на рисунке ниже:

Свойства типа значения INN_IP

Рисунок 12. Свойства типа значения INN_IP

Здесь мы указали имя типа INN_IP (ИНН для ИП) и определили для него ограничение — это должна быть строка длиной 12 знаков.

Обратите внимание, что для названий типов веб-сервиса нужно выбирать англоязычные имена. В дальнейшем они будут использоваться на стороне клиента для генерации классов, а с кириллицей где-то могут возникнуть сложности.

Теперь нам нужно задать ограничение: 12 знаков должны быть цифрами. Выделяем свойство INN_IP и вызываем меню Добавить->Образец:

Добавляем шаблона заполнения INN_IP

Рисунок 13. Добавляем шаблона заполнения INN_IP

Заполняем свойство образца шаблоном в виде регулярного выражения [0-9]{12}. То есть мы допускаем в значении 12 цифр от 0 до 9.

Шаблон заполнения INN_IP

Рисунок 14. Шаблон заполнения INN_IP

Подобные действия нужно произвести с INN_UL (ИНН юрлица) и KPP (КПП):

Рисунок 15. Добавляем типы значений и устанавливаем шаблоны

И для телефона (шаблон [+][7][ ][(][0-9]{3}[)][ ][0-9]{3}[-][0-9]{2}[-][0-9]{2}):

Рисунок 16. Типа значения Phone и шаблон его заполнения

Теперь перейдем к определению типов для данных о клиентах.

У нас есть три типа клиентов: Юрлицо, ФизЛицо и ИП.  Для всех типов клиентов правила заполнения ИНН и КПП отличаются. Можно сделать только один класс Customer и контроль заполнения ИНН и КПП производить программно, но удобнее это делать декларативно — чтобы уменьшить возможность ошибок. Мы создадим три комплексных типа: CustomerIP, CustomerUL и CustomerFL. Значения ИНН и КПП будем выбирать из ранее созданных типов значений.

Для создания клиента ФизЛицо выделим корень пакета и вызовем меню Добавить -> ТипОбъекта. В свойствах укажем следующие значения:

Рисунок 17. Свойства типа объекта CustomerFL

  • CustomerFL — это имя типа. Должно быть на английском.
  • ComplexType — базовый тип, аналогичный структуре.

Выделим тип объекта CustomerFL и вызовем меню Добавить->Свойство. Заполним в редакторе свойств значения:

Рисунок 18. Добавляем свойство FullName в тип объекта CustomerFL

  • FullName — имя свойства. Должно быть на английском.
  • Тип string — строковый тип.
  • Поле FullName должно быть обязательно заполнено указываем Возможно пустое — Ложь.

Таким же образом добавим свойства Phone и GUID.

Свойства типа объекта CustomerFL

Рисунок 19. Добавляем свойство Phone в тип объекта CustomerFL

Добавляем свойство GUID в тип объекта CustomerFL

Рисунок 20 Добавляем свойство GUID в тип объекта CustomerFL

Затем добавим тип объекта CustomerIP с такими же свойствами, как у CustomerFL, добавив новое свойство INN.

Добавляем свойство INN в тип объекта CustomerIP

Рисунок 21. Добавляем свойство INN в тип объекта CustomerIP

Дальше создадим тип объекта CustomerUL с такими же свойствами, как у CustomerIP. Добавим новое свойство KPP.

Добавляем свойство KPP в тип объекта CustomerUL

Рисунок 22. Добавляем свойство KPP в тип объекта CustomerUL

У свойства INN нужно изменить тип на INN_UL (http://kursy-po-1c.ru/ws/wsextension).

Добавляем свойство INN в тип объекта CustomerUL

Рисунок 23. Добавляем свойство INN в тип объекта CustomerUL

Мы завершили создание XDTO-пакета.

Новый XDTO-пакет

Рисунок 24. Новый XDTO-пакет

Переходим к разработке веб-сервиса.

Создаем веб-сервис

В ветке метаданных Общие выделяем ветку Web-Сервисы. Вызываем контекстное меню Добавить и заполняем свойства нового веб-сервиса:

Заполняем свойства веб-сервиса

Рисунок 25. Заполняем свойства веб-сервиса

  • Имя — ak_Customers
  • ПакетыXDTO — http://kursy-po-1c.ru/ws/wsextension. Теперь сможем использовать типы данных, которые определены этом пакете.
  • URI пространства — http://kursy-po-1c.ru/ws/wsextension. Пространство имен будет использоваться клиентами веб-сервиса.
  • Имя файла публикации — Customers.1cws. Имя будет использоваться в URL для получения WSDL.

Теперь добавим метод веб-сервиса, который будет записывать в УНФ нового контрагента-физлицо. Вызываем меню Добавить->Операция и заполняем свойства:

Свойства метода AddCustomerFL

Рисунок 26. Свойства метода AddCustomerFL

  • Имя — имя метода веб-сервиса. Будет использоваться при обращении к сервису извне.
  • Тип возвращаемого значения — тип данных, который возвращает сервис. В нашем случае это строка-уникальный идентификатор, который в будет возвращен в CRM.
  • Имя процедуры — имя процедуры в модуле сервиса, которая будет выполняться при обращении к этому методу.

Далее мы добавим параметры, которые будут передаваться в веб-сервис.

В нашем случае это один параметр — Customer. Для добавления параметра выделяем операцию веб-сервиса и вызываем контекстное меню Добавить->Параметр. В свойствах этого параметра заполняем свойства:

Свойства параметра Customer

Рисунок 27. Свойства параметра Customer

  • Имя — имя параметра метода сервиса. Будет виден на клиенте веб-сервиса.
  • Тип значения — тип значения, определенный в нашем пакете.

Добавим еще две операции:

  • AddCustomerIP
  • AddCustomerUL.

Можно сделать это копированием. Затем нужно поменять имена операций, имена процедур-обработчиков (AddCustomerIP и AddCustomerUL) и типы параметров. Для AddCustomerIP тип параметра установим CustomerIP, а для AddCustomerUL — CustomerUP.

Теперь нужно создать процедуры-обработчики методов сервиса.

  //Добавляем ФизЛицо
  Функция AddCustomerFL(Customer)
      Возврат ДобавитьКлиента(Customer, Перечисления.ВидыКонтрагентов.ФизическоеЛицо);
  КонецФункции

  //Добавляем ЮрЛицо
  Функция AddCustomerUL(Customer)
      Возврат ДобавитьКлиента(Customer, Перечисления.ВидыКонтрагентов.ЮридическоеЛицо);
  КонецФункции

  //Добавляем ИП
  Функция AddCustomerIP(Customer)
      Возврат ДобавитьКлиента(Customer, Перечисления.ВидыКонтрагентов.ИндивидуальныйПредприниматель);
  КонецФункции

  //Добавляем контрагента в базу УНФ
  Функция ДобавитьКлиента(Клиент, ВидКонтрагента)
      //Создаем нового контрагента и заполняем общие реквищиты
      НовыйКлиент = Справочники.Контрагенты.СоздатьЭлемент();
      НовыйКлиент.ВидКонтрагента = ВидКонтрагента;
      НовыйКлиент.Наименование = Клиент.FullName;
      НовыйКлиент.НаименованиеПолное = Клиент.FullName;
      НовыйКлиент.Покупатель = Истина;
      //Для ЮрЛица и ИП заполняем ИНН
      Если ВидКонтрагента <> Перечисления.ВидыКонтрагентов.  ФизическоеЛицо Тогда
        НовыйКлиент.ИНН = Клиент.INN;
      КонецЕсли;
      //Для ЮрЛица заполняем КПП
      Если ВидКонтрагента = Перечисления.ВидыКонтрагентов.ЮридическоеЛицо Тогда
          НовыйКлиент.КПП = Клиент.KPP;
      КонецЕсли;
      //Заполняем контактные данные
      Телефон = НовыйКлиент.КонтактнаяИнформация.Добавить();
      Телефон.Тип = Перечисления.ТипыКонтактнойИнформации.Телефон;
      Телефон.Вид = Справочники.ВидыКонтактнойИнформации.ТелефонКонтрагента;
      Телефон.НомерТелефона = Клиент.Phone;
      Телефон.Представление = Клиент.Phone;
  
    //Записываем клиента в базу
      НовыйКлиент.Записать();
      //Возвращаем ссылку в виде уникального идентификатора (GUID)
      Возврат XMLСтрока(НовыйКлиент.Ссылка);
  КонецФункции

Код простой и каких-то особых комментариев не требует.

Публикуем веб-сервис на сервере

Для публикации веб-сервиса должны быть установлены:

  • Веб-сервер (Apache или IIS)
  • Платформа 8.3.7 и выше с установленным расширением веб-сервера

О подготовке рабочего окружения можно прочитать в статье Как настроить обмен 1С с интернет-сервисами.

Для публикации веб-сервиса нужно запустить конфигуратор с правами администратора. Для этого вызываем контекстное меню и выбираем «Запуск от имени администратора»:

Запуск конфигуратора от имени администратора

Рисунок 28. Запускаем конфигуратор от имени администратора

После открываем меню Администрирование->Публикация на веб-сервере. В открывшемся окне заполняем настройки:

Публикация веб-сервиса

Рисунок 29. Публикация веб-сервиса

  • Имя — имя базы для публикации на сервере. Будет являться частью URL.
  • Веб-сервер — на нем будет опубликована база. В нашем случае используется Apache 2.4.
  • Каталог — место на диске, куда будет помещен default.vrd.
  • Публиковать веб-сервисы — отмечаем.
  • Публиковать веб-сервисы расширений по умолчанию — отмечаем, чтобы веб-сервисы были доступны из расширений.

Жмем Опубликовать.

Проверим, что веб-сервис опубликовался. Для этого запустим браузер и в адресной строке введем http://localhost/UNF/ws/Customers.1cws?wsdl. В результате в браузере должен отобразиться XML.

Проверяем работу веб-сервиса

Рисунок 30. Проверяем работу веб-сервиса

Если в вашей базе есть пользователи, то при обращении по указанной ссылке  будет запрошен логин и пароль. Нужно ввести логин и пароль администратора информационной базы.

Чтобы в дальнейшем не отвлекаться на пароли при изучении статьи (тему безопасности мы сознательно опускаем), откроем в текстовом редакторе файл default.vrd, (он лежит в каталоге, указанном при публикации). В него запишем логин и пароль в строке подключения: ib=”File=&quot;D:\1CBase\UNF&quot;;usr=admin;pwd=12345;”. Логин, пароль и путь должны быть от вашей базы 1С.

Тестируем веб-сервис

Для проверки работоспособности сервера можно создать отдельную базу 1С и добавить в ней обработку ТестВебСервера со следующими реквизитами:

  • FullName, строка(100)
  • INN, строка(12)
  • KPP, строка(9)
  • Phone, строка(20)

Реквизиты выводим на форму и добавляем три кнопки:

  • Создать ФизЛицо
  • Создать ЮрЛицо
  • Создать ИП.

Обработка для проверки веб-сервиса

Рисунок 31. Обработка для проверки веб-сервиса

В модуле формы напишем такой код:

  //1. Обработчики кнопок
  //Обработчик кнопки СоздатьФизЛицо
  &НаКлиенте
  Процедура СоздатьФизЛицо(Команда)
      СоздатьКлиентаНаСервере("CustomerFL");
  КонецПроцедуры

  //Обработчик кнопки СоздатьИП
  &НаКлиенте
  Процедура СоздатьИП(Команда)
      СоздатьКлиентаНаСервере("CustomerIP");
  КонецПроцедуры

  //Обработчик кнопки СоздатьЮрЛицо
  &НаКлиенте
  Процедура СоздатьЮрЛицо(Команда)
      СоздатьКлиентаНаСервере("CustomerUL");
  КонецПроцедуры

  //Создание клиента
  &НаСервере
  Процедура СоздатьКлиентаНаСервере(ТипКлиента)
      //2. Получаем описание сервиса
      ВСОпределение = Новый WSОпределения("http://localhost/UNF/ws/Customers.1cws?wsdl");
      //3. Создаем прокси для обращения к сервису
      Прокси = Новый WSПрокси(ВСОпределение, "http://kursy-po-1c.ru">kursy-po-1c.ru/ws/wsextension", "ak_Customers", "ak_CustomersSoap");
      //4. Получаем тип клиента по URI пространству имен и имени типа
      ТипКлиент = Прокси.ФабрикаXDTO.Тип("http://kursy-po-1c.ru">kursy-po-1c.ru/ws/wsextension", ТипКлиента);
      //5. Создаем XDTOОбъект заданного типа
      Клиент = Прокси.ФабрикаXDTO.Создать(ТипКлиент)      ;
      //6. Заполняем данные Клиента данными, введенными в форме
      ЗаполнитьЗначенияСвойств(Клиент, Объект);
      //7. В зависимости от типа клиента вызываем соответствующий метод веб-сервиса
      Если ТипКлиента = "CustomerFL" Тогда
          Объект.GUID = Прокси.AddCustomerFL(Клиент);
      ИначеЕсли ТипКлиента = "CustomerIP" Тогда
          Объект.GUID = Прокси.AddCustomerIP(Клиент);
      ИначеЕсли ТипКлиента = "CustomerUL" Тогда
          Объект.GUID = Прокси.AddCustomerUL(Клиент);
      КонецЕсли;
  КонецПроцедуры

Прокомментируем код:

  1. В обработчиках кнопок вызываем процедуру СоздатьКлиентаНаСервере() и передаем название типа клиента в виде строки.
  2. Получаем WSDL-описание веб сервиса, опубликованного по указанному в параметрах URL. На основании него создается объект WSОпределение.
  3. Создаем объект Прокси для работы с сервисом. Он позволяет обращаться к веб-сервису, вызывая его методы в привычном объектном стиле. В качестве параметров передаем WSОпределение сервиса, созданное на предыдущем шаге, пространство имен веб-сервиса, имя веб-сервиса и точку подключения. Имя точки подключения формируется путем добавления к имени сервиса суффикса Soap (так формирует WSDL 1C).
  4. Получаем тип клиента по URI пространства имен.
  5. На основании типа клиента, полученного на предыдущем шаге, создаем XDTOОбъект Клиент. По структуре этот объект будет соответствовать структуре типа, который мы определяли в нашем XDTO-пакете.
  6. Заполняем значения реквизитов клиента данными, введенными в форме;
  7. В зависимости от переданного в процедуру типа клиента, мы вызываем разные методы веб-сервиса. «Под капотом» этого вызова произойдет сериализация данных в XML, валидация XML, формирование HTTP пакета и отправка его на сервер.

С этой обработкой можно поэксперементировать. Попробуйте создавать клиентов разных типов, введя корректные данные и некорректные. Если вы попытаетесь ввести в ИНН буквы или заполнить телефон, не соблюдая формат, то появится окно ошибки.

Итак, в данной статье мы познакомились с возможностями платформы по разработке веб-сервисов без снятия конфигурации с поддержки. Создали расширение, импортировали в расширение нужные нам объекты метаданных и описали модель данных для обмена. Создали и опубликовали веб-сервис. Написали обработку на 1С для проверки работоспособности этого сервиса.

На этом пока закончим, но не остановимся :-)

Об авторе

Автор статьи – Алексей Дубровин, г. Челябинск

E-mail: dubrovin1973@gmail.com

Нужно быстро разобраться в работе расширений?

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

Комментарии / обсуждение (57):

  1. stroka

    Здравствуйте
    Рис.29
    В таблице, где Имя и Адрес ни одной галки не стоит.
    Надо их ставить? В каком случае надо, а в каком — нет?
    Для чего эта таблица и ее содержимое?

    • AlexeyDubrovin

      Добрый день
      В этой таблице размещены веб-сервисы, которые определены в конфигурации. Если Вам нужен какой-либо из этих сервисов (планируете к ним обращаться), то надо поставить галочку. Если не планируете их использовать, то галку лучше снять, чтоб кто-нибудь “случайно” их не использовал.

      • stroka

        Здравствуйте. Да, с этим понятно.
        А в коде под рис.31 в строке
        Прокси = Новый WSПрокси(ВСОпределение, “http://http://kursy-po-1c.ru”>kursy-po-1c.ru/ws/wsextension”, “ak_Customers”, “ak_CustomersSoap”);
        всё верно?
        Когда делаю так, выдает много ошибок:
        ===========
        {Обработка.ТестВебСервера.Форма.Форма.Форма(33,83)}: Неправильная константа типа Число
        Прокси = Новый WSПрокси(ВСОпределение, “http://http://kursy-po-1c.ru”>kursy-po-<>1c.ru/ws/wsextension”, “ak_Customers”, “ak_CustomersSoap”); (Проверка: Сервер)
        {Обработка.ТестВебСервера.Форма.Форма.Форма(33,85)}: Ожидается символ ‘)’
        Прокси = Новый WSПрокси(ВСОпределение, “http://http://kursy-po-1c.ru”>kursy-po-1c<>.ru/ws/wsextension”, “ak_Customers”, “ak_CustomersSoap”); (Проверка: Сервер)
        {Обработка.ТестВебСервера.Форма.Форма.Форма(33,83)}: Неправильная константа типа Число
        Прокси = Новый WSПрокси(ВСОпределение, “http://http://kursy-po-1c.ru”>kursy-po-<>1c.ru/ws/wsextension”, “ak_Customers”, “ak_CustomersSoap”); (Проверка: Тонкий клиент)
        {Обработка.ТестВебСервера.Форма.Форма.Форма(33,85)}: Ожидается символ ‘)’
        Прокси = Новый WSПрокси(ВСОпределение, “http://http://kursy-po-1c.ru”>kursy-po-1c<>.ru/ws/wsextension”, “ak_Customers”, “ak_CustomersSoap”); (Проверка: Тонкий клиент)
        {Обработка.ТестВебСервера.Форма.Форма.Форма(33,83)}: Неправильная константа типа Число
        Прокси = Новый WSПрокси(ВСОпределение, “http://http://kursy-po-1c.ru”>kursy-po-<>1c.ru/ws/wsextension”, “ak_Customers”, “ak_CustomersSoap”); (Проверка: Сервер)
        {Обработка.ТестВебСервера.Форма.Форма.Форма(33,85)}: Ожидается символ ‘)’
        Прокси = Новый WSПрокси(ВСОпределение, “http://http://kursy-po-1c.ru”>kursy-po-1c<>.ru/ws/wsextension”, “ak_Customers”, “ak_CustomersSoap”); (Проверка: Сервер)
        {Обработка.ТестВебСервера.Форма.Форма.Форма(33,83)}: Неправильная константа типа Число
        Прокси = Новый WSПрокси(ВСОпределение, “http://http://kursy-po-1c.ru”>kursy-po-<>1c.ru/ws/wsextension”, “ak_Customers”, “ak_CustomersSoap”); (Проверка: Тонкий клиент)
        {Обработка.ТестВебСервера.Форма.Форма.Форма(33,85)}: Ожидается символ ‘)’
        Прокси = Новый WSПрокси(ВСОпределение, “http://http://kursy-po-1c.ru”>kursy-po-1c<>.ru/ws/wsextension”, “ak_Customers”, “ak_CustomersSoap”); (Проверка: Тонкий клиент)
        =====================
        Когда эту строку меняю на:
        Прокси = Новый WSПрокси(ВСОпределение, “http://kursy-po-1c.ru/ws/wsextension”,”ak_Customers”, “ak_CustomersSoap”);
        , в этой строке уже ошибки нет (она появляется, но дальше).

          • stroka

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

            (возможно, такая статья тоже есть?)

            • AlexeyDubrovin

              Добрый день
              Это демонстрация одного из инструментов обмена (транспортный уровень), доступный в 1С.
              В типовых его сейчас используют для передачи файлов, полученных с помощью КД2 или КД3.
              Пример использования веб-сервисов в связке с планом обмена и самодельной сериализацией есть в желтой книжке про разработку мобильных приложений
              Моих статей пока нет

              • stroka

                Можно название и автора этой желтой книжки (а то в этой сфере вроде все книжки в желто-оранжевых тонах)?

                  • stroka

                    Здравствуйте. Спасибо за ссылку на книгу.

                    Подскажите, пожалуйста, почему в статье веб-сервис расположен в базе, в которую переносятся данные, а не в базе-источнике?
                    Почему не наоборот?
                    Что изменилось бы в этом случае?

                    • AlexeyDubrovin

                      Здравствуйте, потому что это было бы странно, вызывать процедуру в той же базе через веб-сервис. Веб-сервис нужен для того, чтобы сделать что-то в другой базе

  2. Игорь

    если планируется использование в 1c web и http сервисов нужно ли при установке 1с выбирать к установке web – расширения?

  3. Alex

    Добрый день!
    При попытке записать клиента выдается сообщение об ошибке
    При вызове веб-сервиса произошла ошибка. При создании описания сервиса произошла ошибка. URL сервиса: https://localhost/WebTest/ws/Customers.1cws?wsdl
    по причине:
    Ошибка работы с Интернет: Удаленный узел не прошел проверку
    Подскажите, в чем может быть проблема

    • AlexeyDubrovin

      У вас https указан, а ssl-сертификат не установлен. При создании http-соединения уберите параметр защищенного соединения

      • amun886

        Здравствуйте!
        “https” нигде не указывал, делал все по инструкции, но такая же проблема:

        При вызове веб-сервиса произошла ошибка. Ошибка SOAP сервера: Неизвестная ошибка. Предупреждение безопасности
        Открывается “ИнтеграцияВебСервисы”.
        Рекомендуется обращать внимание на источник, из которого был получен данный файл. Если с источником нет договоренности о разработке дополнительных модулей, или есть сомнения в содержимом файла, то его не рекомендуется открывать, поскольку это может нанести вред компьютеру и данным.
        …Код ошибки: Client
        Техническая информация:
        detail xmlns:soap=”http://schemas.xmlsoap.org/soap/envelope/”

        не понимаю как “убрать параметр защищенного соединения”… Оба нижних варианта не срабатывают:
        Вариант 1.
        Прокси = Новый WSПрокси(ВСОпределение, “http://kursy-po-1c.ru/ws/wsextension”, “WS1_Customers”, “WS1_CustomersSoap”);
        Вариант 2.
        Прокси = Новый WSПрокси(ВСОпределение, “http://kursy-po-1c.ru/ws/wsextension”, “WS1_Customers”, “WS1_CustomersSoap”, , , Неопределено);

        • AlexeyDubrovin

          Добрый день
          Тут уже явно не про https. Это надо посмотреть на галки Безопасный режим и Защита от опасных действий в расширении.

  4. Beard

    Доброго!
    Если никогда не сталкивался ни с WEB – сервисами, ни с HTTP – сервисами, то в чью сторону посоветуете смотреть сегодня?

    • AlexeyDubrovin

      Если хотите быть специалистом, то смотрите и туда и туда. Моднее HTTP-сервисы

    • lazarev_molvest

      Добрый день. Кратко ответить на такой вопрос не получится, но наверняка вопрос, что выбрать из RESTful и SOAP, стоит перед многими, поэтому попробую описать отличия.
      HTTP-сервисы обычно имеют архитектуру REST(ful) – если своими словами, то мы определяем, к каким сущностям можно обращаться (Контрагент, Заказ и т.п.), определяем поведение HTTP типов запросов (GET, POST, PUT, DELETE, PATCH и т.п.) и можно работать. Транспорт – всегда HTTP. Архитектура не является четкой, полностью зависит от программиста, то есть ввод заказов можно сделать через GET и как хотите, так это и понимайте. Сервис сам себя не документирует, то есть без документа от разработчика вы не догадаетесь, что отправлять на сервер новый заказ нужно через GET. Отличительной характеристикой REST является относительно гибкая модель маршрутизации и отсутствие дополнительных накладных расходов на парсинг результата запроса на стороне клиента. Особо подчеркну: это протокол, оптимальный для связи между фронтендом и бекендом! То есть у вас страничка на js, которая отправляет минимальный запрос беку “верни мне заказ с id 123”, получает родной json, ловко его конвертит в объектную модель и тут же можно работать дальше. Хорошим примером использования REST в 1С является автоматическая реализация OData, ссылка на ИТС: https://its.1c.ru/db/v8315doc#bookmark:dev:TI000001358 узнаете много нового.
      К великому сожалению, REST называют “модным”, поэтому лепят его туда, куда его лепить не надо. Например, полноценный обмен данными между Enterprise системами.
      Для такой задачи создан давным-давно SOAP и актуальность он не потеряет еще с полвека. Транспорт для SOAP может быть любым, но чаще встречается HTTP. Модель SOAP сервиса (в 1С называется веб-сервисом) декларируется в файле WSDL, который можно открыть например в SoapUI и получить готовые http-запросы и даже виртуальный сервер для отладки клиента. Основное отличие от REST первое – в первом используются понятия сущности (конкретный заказ или список заказов), в SOAP используются понятия методов (процедуры и функции с параметрами и возвращаемым ответом); второе – за счет архитектуры WSDL у вас интеграция по SOAP будет либо не работать вообще, либо работать правильно, в отличие от REST, где никто никому ничего не обещает.
      Если вы планируете обмен между системами, которые разрабатывают разные команды – SOAP дает огромную фору всем остальным протоколам за счет автодокументирования контракта, любое неожиданное изменение сразу разрушит обмен, это будет видно моментально и быстро определится виновник, баги в обмен не пройдут. Но в примере выше связи фронта и бека простой страничке придется парсить XML, валидировать его по схеме и так далее – поэтому оба инструмента имеют свое применение, путать их нельзя

      • AlexeyDubrovin

        В общем все верно, но Вы слишком категоричны в части “за счет архитектуры WSDL у вас интеграция по SOAP будет либо не работать вообще, либо работать правильно, в отличие от REST, где никто никому ничего не обещает”. Правильно разработанный API для REST будет работать правильно, а SOAP можно так испохабить, что “никто ничего не будет обещать”.
        90% виденных мной web-сервисов на 1С тупо слали XML как строку без всяких там XDTO. В этом случае проверится только наличие метода и что параметр – строка. В строку можно запихнуть что душе угодно. Вот и потеряны все плюсы SOAP. С другой стороны, можно в REST послать XML, а на другой стороне проверить его на соответствие XSD.

        SOAP хорош самодокументированностью, определенной строгостью, позволяет различным IDE автоматом создавать каркасы классов для работы с сервисом на основе WSDL, но довольно “многословен” и более медленный, за что его и невзлюбили многие

        REST более легкий, быстрый (при правильной проработке API), но не налагает на разработчика особых требований. Это позволяет ленивым программистам делать кривые реализации, что приводит в результате к мифам, что REST штука несерьезная. Гляньте на ту же oData. Тоже REST, а вполне себе серьезный протокол, причем рожденный не в 1С https://www.odata.org/

  5. Сергей

    Добрый день!
    Сделал все, как написано в статье, единственное, добавил авторизацию.
    URL в браузере работает, запрашивает логин, пароль, после ввода корректного логина/пароля – в браузере показывается xml
    Но, когда обращаюсь к веб-сервису из обработки 1С, – выдается сообщение:

    При вызове веб-сервиса произошла ошибка. Ошибка HTTP: HTTP Status 500 – Внутренняя ошибка сервера.
    и далее символы в непонятной кодировке
    Вот скриншот:
    https://ibb.co/4fNCLRQ
    Подскажите, в чем может быть причина такой ошибки?

    • AlexeyDubrovin

      Ошибка 500 означает, что при выполнении кода веб-сервиса произошла какая-то ошибка. Посмотрите в журнале регистрации этой базы.

      • Сергей

        К сожалению, в журнал регистрации базы, в которой выполнялась обработка, записалась ровно такая же информация, как и в сообщении об ошибке.

      • Сергей

        В модуле веб-сервиса попробовал в функции AddCustomerFL вернуть просто обычную строку
        Вот так:
        Функция AddCustomerFL(Customer)
        //Возврат ДобавитьКлиента(Customer, Перечисления.ВидыКонтрагентов.ФизическоеЛицо);
        Возврат “Ответ веб-сервиса”;
        КонецФункции
        Переопубликовал веб-сервис, но при тестировании все равно та же ошибка 500
        Если ошибиться в формате написания например номера телефона, то возникает сообщение
        “Ошибка проверки данных XDTO: … Значение не соответствует образцу”
        https://ibb.co/xXJP895
        То есть можно сделать вывод, что обработка соединяется с веб-сервисом

  6. Человек

    не понимаю зачем создавать обработку для проверки ? в реальной жизни тоже обработку будем делать?

    • AlexeyDubrovin

      В реальной жизни можем даже веб-сервисы писать не обязательно, а писать, например, стихи :)
      Но тут надо было как-то показать, что сервис работает, а заодно показать как к этому сервису можно обращаться из 1С.
      Примеры на других языках программирования могли бы быть не понятны для тех, кто этими языками не владеет. Поэтому обработка на 1с.
      В принципе, можно пользоваться для тестирования инструментами типа SOAPUI

  7. Евгений

    Спасибо за статью. Познавательно!
    Будет ли работать такое расширение, если сама УНФ расположена в облаке? Например, в 1cFresh?

    • Dubrovin

      Все зависит от того, что это за облако и что в нем позволено пользователям. По поводу фреша – в принципе работать это там должно. Расширения разрабатывать для фреша возможно, но есть определенные требования и определенная процедура публикации своих расширений. Почитать можно здесь https://1cfresh.com/articles/so_confext

    • Vitims

      “Для AddCustomerIP тип параметра установим CustomerIP, а для AddCustomerUL — CustomerUP.”
      Ошибка, вместо CustomerUP нужно CustomerUL. Хотя у кого то выше и так работает… загадка.

  8. q_i

    Добрый день!
    В статье написано:
    “Для проверки работоспособности сервера можно создать отдельную базу 1С и добавить в ней обработку ТестВебСервера со следующими реквизитами: FullName, строка(100) INN, строка(12) KPP, строка(9) Phone, строка(20)”.
    На форме видно ещё поле GUID, и в коде его тоже заполняете: “Объект.GUID = Прокси.AddCustomerXX(Клиент);”. Наверное, оно тоже должно быть в списке реквизитов?

    • Dubrovin

      Вы правы, должно. FullName, INN, KPP и Phone передаются в качестве параметров в метод веб-сервиса, который возвращает обратно GUID для записи в CRM. Спасибо за внимательность

  9. vic777tor

    Спасибо за статью!
    Очень наглядно описано что это за зверь такой: XDTO пакет :)

    • Кузьмин Сергей

      В будущем планируем вернуть pdf-версии, но это произойдет не ближайшие дни.

  10. Ленар Ильгизович

    Спасибо. Очень полезная информация. У меня очень маленький опыт работы с веб сервисами, я бы хотел уточнить… в описанном примере используются две базы данных УНФ и CRM, правильно ли я понял, 1. что веб-сервис разрабатывается на стороне УНФ? 2. А внешняя обработка для проверки веб-сервиса ( которая создает контрагента) моделирует CRM? Если ответ на 2. Да, тогда нужно в CRM также вносить изменения.

    • Dubrovin

      Да, веб-сервис на стороне УНФ. Обработка эмулирует работу CRM. Возможно, что CRM придется дописывать. Возможно, что CRM уже имеет какое-то API, и Вам придется реализовывать веб-сервисы или http-сервисы под их требования. Писал подобное для интеграции JIVO-Site c УТ10.3. У Jivo есть API WebHooks. Они шлют http-запрос с JSON внутри при наступлении определенных событий. В админке нужно прописать URL на свой http-сервис. Ничег дописывать со стороны JIVO не требовалось. В amoCRM тоже довольно развитое API для интеграции с 1С. Там вроде тоже можно к 1С обращаться.

  11. gosn1ck

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

    • Dubrovin

      Ну да. Даже в стандартном наборе типов W3C описано много типов с различными ограничениями. Все в одну статью не впихнуть. Я сознательно упрощал и пользовался примитивными типами, про которые не надо отдельно писать что в них и для чего.

  12. petypen

    Добрый день.
    На скриншоте Рисунок 19. Добавляем свойство Phone в тип объекта CustomerFL
    похоже ошибка в указании типа значения.

    Спасибо, за отличные статьи.

  13. Аркадий

    что то не удобно читать, картинки появляются не сразу, надо мотать намного ниже по тексту а потом отматывать обратно. браузер chrome

    • Dubrovin

      Можно и заменить. Но статья про HTTP-сервисы уже была, а про веб-сервисы – нет. :-)
      Есть какие-то проблемы сделать HTTP-сервисы в расширении ?

      • Khalimanov

        Не понятно, как указывать настройки (например reuseSessions) для сервисов из расширений.

        • AlexeyDubrovin

          ReuseSessions настраивается установкой свойства веб-сервиса ПовторноеИспользованиеСеансов. Может принимать три значения ИспользоватьАвтоматически (autouse), Использовать (use) и НеИспользовать (dontuse). С версии 8.3.9 можно эту настройку устанавливать и править в файле default.vrd, который имеет приоритет выше, чем конфигурация.

          • Khalimanov

            Не понимаю как устанавливать эти поля для сервисов из расширений: есть одно поле publishExtensionsByDefault. Если есть 2 сервиса в одном расширении, как для каждого указать свое ПовторноеИспользованиеСеансов?

            • AlexeyDubrovin

              Ну, если брать платформу 8.3.11, то там в расширениях уже доступно редактирование этого свойства прямо из редактора свойств веб-сервиса (двойной клик по веб-сервису и на закладке УправлениеСеансами правим. Если в файле default/vrd, то в тэге point можно ручками каждый сервис прописать c нужными настройками

Добавить комментарий

Ваш e-mail не будет опубликован. Обязательные поля помечены *

Вход на сайт

Зарегистрироваться

Подтверждение регистрации будет отправлено на указанный e-mail.

Я подтверждаю, что ознакомлен(а) с Пользовательским соглашением, принимаю его условия и даю свое согласие на обработку моих персональных данных.

Восстановить доступ

E-mail или логин

Ссылка на создание нового пароля будет отправлена на указанный e-mail.