XDTO — это просто, часть 2

Моя первая статья про XDTO получила широкую поддержку. Большое спасибо всем, кто оставил отзывы. Видно, что тема является актуальной, посему — продолжение.

XDTO — это просто, часть 2

 

Обновление 28.01.2013:

Опубликована очередная статья: //infostart.ru/public/171019/

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

Стоит также отметить, что данная статья, по сути, является прямым продолжением первой статьи, т.е. все, что будет написано ниже должно было быть включено в первую статью, но она, неожиданно для меня, получилась довольно большой и ее пришлось разбить на две. Таким образом, обе статьи следует считать одной, тема здесь и там рассматривается одна и та же — самые основы-основ XDTO с минимумом "внутренностей". Более детальные обзоры требуют понимания фундамента, поэтому, данная вводная часть, хоть и не так интересна, но, тем не менее, просто обязана быть. Еще раз, хочу обратить внимание — если материал статьи Вам и так известен, пролистайте ее, а в комментариях напишите те вопросы, которые нужно осветить подробно в будущих статьях.

 

Liquid XML Studio

Как я уже говорил, для разработки схем я пользуюсь Liquid XML Studio, а стало быть примеры схем будут приведены для этой программы. Разумеется, никто не запрещает создавать схемы любыми другими редакторами, например XML Spy или Oxygen. Старый добрый Блокнот тоже никто не отменял ;). Да, забыл! В 1С есть встроенный редактор типов XDTO. Он чуть лучше, чем блокнот, поэтому, запросто можно использовать его для небольших схем.

Какие бывают типы?

Как я уже говорил, фундаментальным понятием для XDTO является модель типов, т.е. совокупность всех прикладных (полезных бизнес-логике) типов данных. Прикладных типов может быть много, но по принципу построения все они похожи.

Во-первых, типы делятся на простые (simple) и составные (complex). Составные типы могут иметь несколько моделей содержимого, но XDTO поддерживает только простые последовательности свойств — так называемые sequence. Вдаваться в особенности моделей содержимого не будем. Sequence — это просто перечень свойств, как реквизиты справочника, например. Остальные в рамках данной темы нам не интересны.

Простые типы представляют данные, которые можно выразить одним строковым значением, например даты, строки и числа. Составные, как следует из названия, это типы содержащие несколько значений.

Стандарты XML представляют большое количество базовых типов данных. Все их перечислять нет смысла, некоторые будут в примерах, при необходимости, их можно найти в стандартах w3c, а также в гугле.

Типы могут наследовать друг-друга, так же, как в любимом всеми ООП. Например, “ФизЛицо” с атрибутами имени, номера паспорта и адресом может наследоваться типами “Сотрудник” и “Клиент”. На наследовании останавливаться не будем, думаю, все знают, что это такое. Кроме того, свойства в составных типах данных могут иметь так называемую “повторяемость”, т.е. встречаться в документе более 1 раза. По-простому, это называется список.

Как тип данных может выглядеть в XML?

Рассмотрим небольшой тип данных, который описывает одно сообщение в сетевом чате типа аськи:
У сообщения есть уникальный номер, дата-время его поступления на сервер и, собственно, тело сообщения. Здесь интересный момент. Составной тип данных может выглядеть в XML разными способами, но логически означать одно и тоже. В XDTO, как в средстве “логической” обработки данных, все типы будут обрабатываться из языка 1С одинаково, но физически в потоке XML они могут быть представлены разными способами.
Способов представления всего три: Элемент, Атрибут и Текст. Все очень просто — элементы пишутся в XML, как элементы, атрибуты — как атрибуты, а текст — как текст (логично, правда?). Напомним, как выглядят эти вещи в синтаксисе XML:

Обратите внимание, свойства number и date представлены в виде атрибутов, а тело сообщения представлено в виде текста. Если вы разрабатываете свой тип данных, то способы размещения выбирать вам. Атрибут или Элемент — можно холиварить, но в конечном итоге — это дело вкуса.

Никто не запрещает оформить наш тип данных вот так:

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

Конструирование типа в Liquid

Рассмотрим создание указанной модели типов в Liquid. Перво-наперво, создадим чистую схему и зададим ей уникальное пространство имен (вспоминаем первую статью).
В корневом элементе схемы щелкнем правой кнопкой и выберем Add child->Complex type.

Будет добавлен новый тип. Назовем его Message, а в качестве базового укажем string. Базовый тип означает, что наш новый тип в конечном итоге является строкой. Это позволит помещать тело сообщения в текстовый узел XML (см. первую картинку, выше).

Теперь, добавим 2 атрибута — номер и дату сообщения. Правой кнопкой щелкаем на типе Message, выбираем Add child->Attribute. Задаем имя атрибута и тип его значения. Для number — это будет тип decimal (число), для date — dateTime.

Тип Message готов, теперь нужно создать объект пакета сообщений MessagePackage, как в приведенном примере.

Добавляем новый составной тип (корневой элемент, Add child->Complex type), задаем ему имя типа MessagePackage. Базовый тип не указываем.

Теперь еще один момент. Чтобы составной тип мог содержать другие элементы, нужно указать ему модель содержимого. Как я уже говорил, XDTO поддерживает только Sequence. Добавляем в MessagePackage дочерний элемент (правой кнопкой, Add child) и выбираем Sequence. Появится такая серая кракозябла, в которую впоследствии и надо добавлять дочерние элементы.

Щелкнем на этой кракозябле, укажем Add Child — > Element. Для элемента зададим имя (любое), а главное — тип значения — наш тип Message.

В результате получится такая картинка:

Теперь, нам надо указать, что Message может повторяться несколько раз внутри MessagePackage. Для этого, в контекстном меню элемента Message (того, который красненький, ведь это именно он должен повторяться) выберем пункт Cardinality.

Данное свойство позволяет указать особенности повторяемости. Как правило, элементы повторяются либо неограниченное число раз (1..unbounded), либо являются необязательными (т.е. повторяются  от 0 до 1 раз). Если cardinality не указан, что считается, что элемент обязательный и присутствует только один раз.

Для особо тяжелых случаев в свойствах элемента можно настроить точную повторяемость с помощью Min Occurs и Max Occurs. Например, можно указать, что элемент должен встречаться не менее 2-х и не более 10-раз.

Сообщений в нашем пакете может быть одно и более. Указываем Cardinality “1..unbounded”. Теперь элемент Message может повторяться более в пакете более 1 раза. В XDTO такой элемнет будет не просто свойством, а СпискомXDTO.

Обратите внимание, тип Message унаследован от string, а это значит он ЯВЛЯЕТСЯ строкой, просто у этой строки есть 2 дополнительных свойства. Кроме того, само тело сообщения не имеет какого-то имени, к которому можно обратится через точку.

Здесь вступает в игру противоречие между концепцией хранения данных в XML и объектной моделью языка 1С. Например, в общем случае, мы можем объявить тип Message, и из языка 1С задать значение number одной строкой кода:

message.number = 12;

Но что делать, если в схеме нет имени свойства (как в нашем примере с текстом), или свойство называется message-idXML не запрещает дефисы в именах, а вот компилятору 1С вряд ли понравится переменная с дефисом в имени. Мне кажется, это одна из причин, по которой в 1С разделили понятие “Схемы” и понятие “Модели данных”. XML не может однозначно отображаться на объектную модель языка. Требуются дополнительные настройки, а значит, термины, понятия и объекты…

Вернемся в Конфигуратор

Итак, представим, что в корпоративной сети нашей фирмы есть внутренний чат, который называется Corporative Messaging System, сокращенно CMS. Протокол обмена сообщениями — приведенная выше схема. По сети гуляют пакеты сообщений в виде приведенных фрагментов XML. Давайте напишем для этой системы генератор спама на языке 1С.

Сама CMS написана не на 1С, а на Турбо Бейсике 1.0 (чтобы было ясно, что XDTO применимо не только к обмену 1С->1С). При помещении файла XML в специальный каталог он подхватывается сервером CMS и транслируется дальше по сети. Архитектура не ахти какая, но это же Бейсик 1.0, так что не придираемся 🙂

Импорт схемы в конфигуратор

Первое, что мы должны сделать, это выяснить к какому пространству имен относятся типы почтовой системы. В Liquid надо выбрать корневой элемент схемы и открыть окно свойств из контекстного меню. В списке свойств ищем “targetNamespace”. Допустим в нашем примере пространство имен называется “urn:my-company/cms

Теперь, нам надо загрузить схему в конфигуратор. Это мы делали в прошлой статье: щелкаем правой кнопкой на ветке ПакетыXDTO и выбираем “Импорт схемы XML”.
Теперь, откроем на редактирование новый Пакет XDTO и посмотрим, что у него внутри.

Ага, все знакомо, только что это за __content в типе Message? Это как раз то, что платформа предлагает в качестве свойства для текстового содержимого объекта. Модель XDTO предлагает “заменители” для тех имен XML-схемы, которые не могут использоваться в качестве имен переменных в языке 1С. Давайте откроем окно свойств для элемента __content в типе Message.

Обратите внимание, на пункт “Локальное имя”. Он означает то, как свойство представлено в самом файле XML. Пункт “Имя” вверху — то, как объект выглядит в языке 1С. В идеале, они должны совпадать, но если вдруг они различаются, то здесь можно настроить трактовку подобных различий.

Также стоит обратить внимание на пункт “Форма”. Сейчас там стоит “Текст”, это значит, что значение расположено в текстовом узле. Например, если система CMS станет писать message.number не в атрибут, а в обычный элемент, то нам нужно будет поменять поле “Форма” и указать “Элемент”, чтобы новые файлы корректно обрабатывались. А если поле number еще и переименуется в message-id, то надо будет откорректировать “Локальное имя”. Таким образом, независимо (почти) от того, как данные оформлены внутри XML, мы можем настроить то, как они будут выглядеть в языке, а значит при изменении схемы XML нам не придется переписывать код.

Если нам не нравится писать Message.__content = “Hello”, то можно задать другое значение в поле “Имя”. При этом файл будет читаться без ошибок, опираясь на настройку "Форма" и "Локальное имя".

Что там насчет генератора спама?

Да, да. Я не забыл 🙂 Создаем обработку, вешаем на нее большую кнопку и всю необходимую инфраструктуру настроек (текст спама, список адресатов и т.п.).

В самом интересном месте, там где должен формироваться XML документ, код будет выглядеть следующим образом:

ПакетСообщений = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип("urn:my-company/cms"),"MessagePackage");

Для Каждого Адресат Из СписокАдресатов Цикл

    Сообщение = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип("urn:my-company/cms"),"Message");

    Сообщение.number = Адресат.Номер;
   
Сообщение.date = ТекущаяДата();
   
Сообщение.__content = "Купите дубленку";

    ПакетСообщений.Добавить(Сообщение);

    Сообщение = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип("urn:my-company/cms"),"Message");

    Сообщение.number = Адресат.Номер;
   
Сообщение.date = ТекущаяДата();
   
Сообщение.__content = "Уран недорого";

    ПакетСообщений.Message.Добавить(Сообщение);

КонецЦикла;

Запись = Новый ЗаписьXML;
Запись.ОткрытьФайл(ФайлПочтовойСистемы);
ФабрикаXDTO.ЗаписатьXML(Запись, ПакетСообщений);
Запись.Закрыть();

На этом все. Файл со списком сообщений будет корректно сформирован в том месте, где мы указали.

А теперь, следите за руками!

В приведенном примере кода объект Сообщение создается 2 раза. Угадайте, что будет, если убрать вторую строчку “Сообщение = ФабрикаXDTO.Создать”? А будет вот что:

После добавления первого сообщения пакет сообщений содержит 1 элемент. После второго добавления в дерево будет добавлен еще раз тот же самый объект. Загадка: сколько объектов "Сообщение" будет записано в файл XML?

Будет записан только один объект. И этот эффект абсолютно нигде не документирован. Происходит следующее: объект XDTO представляет собой единый граф XML документа. Т.е. все вложенные элементы уникальны, и по объекту XDTO можно гулять вверх-вниз, определяя, какой XML записан выше или ниже объекта. Если мы возьмем объект Message, который уже помещен внутрь списка и присвоим его куда-то еще (например в другой список) то он удалится из первого списка. Объект уникален. Он не будет скопирован в другое место, он будет перемещен, а его связи перестроены.

Еще один пример. Есть тип “Должность” со свойствами “Название” и “Оклад”.

Записываем список сотрудников, где все они имеют должность “Рабочий”

ДолжностьРабочий = СоздатьДолжностьXDTO(); // Фабрика.Создать(.. ля-ля-ля);
СписокСотрудников = СоздатьСписокСотрудников(); // Фабрика.Создать(.. "НекийСписок")
Для Каждого Сотрудник Из Сотрудники Цикл

    xdtoСотрудник = ФабрикаXDTO.Создать("namespace","Сотрудник");
   
xdtoСотрудник.Должность = ДолжностьРабочий; // Это всегда один и тот же объект
   
СписокСотрудников.Добавить(xdtoСотрудник);

КонецЦикла;
ФабрикаXDTO.Записать(ЗаписьXML, СписокСотрудников);

Объект “ДолжностьРабочий” будет гулять от сотрудника к сотруднику, и должность окажется назначенной только у последнего в списке. У всех остальных Должность будет пустой, т.к. она по очереди “перепрыгнула” от одного к другому.

В заключение

В моем редакторе получается 8 страниц. По-моему, для одной статьи даже много и нужно прерваться.

В этой статье мы рассмотрели то, как создаются XML схемы с помощью Liquid и как они отображаются в объекты XDTO. В других редакторах схем они создаются практически так же. Были рассмотрены разные способы задания объектов в XML, определились с терминами “Атрибут”, “Элемент”, “Текстовый узел”. Кроме того, в приведенном примере рассмотрен один нюанс, который с непривычки сложно понять. При присваивании объекта XDTO куда-либо в другом объекте, первый объект удаляется из своего старого места (если он имел таковое), и помещается в новое место. Нельзя один раз создать маленький повторяющийся объект (вроде "Должности"), а потом помещать его в несколько разных других объектов.

На этом предлагаю остановиться. Более подробно копать XDTO будем в одной из следующих статей.

В следующей серии:

Создание собственных Фабрик

Тонкости сериализации

Стандартная XDTO сериализация, с чем едят "СериализаторXDTO" и чем он отличается от "Фабрики".

Запись/чтение XDTO в поток XML, особенности anyType.

89 Comments

  1. siwa99

    Хочу побудить автора на продолжение. Хорошая статья. Дружище, не сбавляй темп.

    Reply
  2. dyak84

    Автор спасибо за статью очень достойное продолжение предыдущей, все очень занимательно и интересно. Полностью согласен с (1). не збавляй темп. СПАСИБО

    Reply
  3. Unicorn31

    +1

    Reply
  4. p1l1gr1m

    Приятно читать статью написанную хорошим, грамотным русским языком. Плюс

    Reply
  5. abc2000

    Особенно заинтересовало создание собственных Фабрик. Требую продолжения.

    🙂

    Reply
  6. DERL

    Все очень грамотно и четко расписано, с множеством скринов. Автор молодец, вот молодец! 🙂

    Reply
  7. kuza_87

    Ждём продолжение)))

    Reply
  8. Den_D

    Неистово плюсую. Прочитал обе части одним махом. Жду с нетерпением следующих.

    Reply
  9. DitriX

    Вот вопрос по этой картинке:



    Тут очень интересный эффект, если не поставить тут минимальное количество 0, а максимальное «-1», то не корректно формируется XDTO пакет.

    Во всяком случае когда форма стоит Элемент.

    Вот тут хотелось бы узнать ваше мнение, откуда такой прикол?

    Reply
  10. Evil Beaver

    (10) DitriX, Не понял вопрос… Если НЕ поставить минимальное 0, а максимальное -1, то что будет некорректно?

    Некорректно будет работать пример кода, взятый из статьи? Ага, скриншот неправильный, так, как на скриншоте это не список получится, а единичный элемент. А вот если в Liquid сделать, как в статье написано, то после импорта в пакете как раз будет стоять 0 и -1.

    Или я не понял вопрос…

    Reply
  11. DitriX

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

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

    Вам не кажется это стрельбой из пушки по воробьям?

    Мне, и думаю большинству из читающих, было бы интереснее познать дзен тонкостей именно в 1С 🙂 ибо именно с ним и работаем. А то так залезешь на чужой сервак, а там буфер отключен, передача данных отключена, а в 1С делать не можем.

    Перефразируя скажу так — если человек решит что то сделать по статье, без помощи Liquid, он ничего более-менее адекватного не сможет сделать, или столкнется с теми же приколами что и я, и, думаю, вы также.

    В чем тогда польза статьи?

    Учтите, вам 90% плюсов ставят авансом, т.е. при надобности все будут рассчитывать на статью, а вот в ней тонкостей то и нету.

    Что то вы уж очень сильно затягиваете весь процесс создания статей.

    Делайте их хотя бы по главам, людям же потом искать их все 🙂

    Если хотите больше плюсов и повисеть на главной, то вопрос снимаю, если для людей делаете — делайте все в одной статье.

    Не хватает так же схем в прикрепленных файлах.

    На заметку — как вы думаете, почему любой пример программирования, в первую очередь, начинается с «Hello world!»? Я думаю, потому что вы сразу видите результат своей работы, от которого можно отталкиваться. А у вас результат то и не приведен. Вы сейчас описываете голый сервер, без клиента, а весь смак то в клиенте, в настройке его и оперированием полученных данных.

    З.Ы. Ничего личного, извините если выглядит как наезд, но эта тема меня действительно интересует, но примеры скудные и по пользе тянет на четверть статьи.

    З.З.Ы. Может я не прав, и других все это устраивает, тогда я просто пойду лесом 🙂

    Reply
  12. DoctorRoza

    Отмечусь, информация нужная!

    Reply
  13. Evil Beaver
    Reply
  14. DitriX

    (14)

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

    Ну вот смотрите, пример из жизни — есть клиенты, у них параноидальный IT отдел, ничего не установить, инета нету, буфер отключен между РДП, т.е. отдельно у себя схемку не накидаешь. А у них стоят андроид отчеты, в которых я юзаю xdto (в новой версии я от них вообще откажусь, но мы не об этом), и вот тут придет мне капут, или ручками ксерить то что накидал в ликвид, или в 1С юзать. Это крайняя ситуация, но и в нужный момент может просто этой программы под рукой не быть.

    Я представлял себе повествование несколько иначе, от фундамента — к принципам работы и только потом — как пользоваться.

    Это хорошо, но вот лично вы — прежде чем программировать за 1С — изначально прочитали всю литературу, которая шла в коробке? Сомневаюсь, вы хотели сразу что то сделать, что бы что то увидеть. И это логично.


    На мой взгляд, как раз «приколы» стандартного редактора можно понять, только если понимаешь сами схемы и то, чем они отличаются от пакетов.

    Ну тут я согласен, есть ньюансы.

    Если Вы знаете, как статью можно разбить на страницы — научите меня, пожалуйста.

    Думаю, что никак нельзя. Но обратитесь в поддержку инфостарта 🙂 Может и сделают.

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

    Про плюсы — был сарказм. Инфостарт — это место, где большему числу откровенно пофиг на карму, плюсы и прочее. Я думаю вы и сами это заметили 🙂

    Reply
  15. Kopman

    Хороший цикл статей, доступно..

    Планируется ли анализ производительности относительно других вариантов разбора XML.

    XDTO- удобно, но хотелось бы понять какая цена этого удобства:-)

    Reply
  16. artmicro

    XDTO очень и очень клевая вещь. У нас например, построен обмен данными между разными конфигурациями именно через XDTO. Да и при обмене с многими внешними системами, тоже удобно использовать XDTO, если требуется создать какого-то вида XML. По факту это Вам и для REST-a подойдет да и вообще, для любого действия с XML. Главное конечно, здравый смысл. Статья хорошая, но тема, как говорится, не расскрыта. Ждем продолжения 🙂

    Reply
  17. zoytsa

    Хотелось бы больше полемики в комментах 🙂

    Reply
  18. Bukaska

    Требуем продолжения банкета!

    Reply
  19. Ksu

    Огромное спасибо автору! Очень полезная статья!

    И большая работа!

    Reply
  20. sikuda

    На будущие статьи. Хотелось освятить тему обработки ошибок XDTO. Когда файл не читается и это происходит из не соответствия данных и схем. Когда я занимался этим в 1С ничего вразумительного найти не смог. Может сейчас дело подвинулось?

    Reply
  21. Evil Beaver

    Дело не может продвинуться. Если файл не соответствует схеме, он читаться не будет. Единственный способ — выяснять — где произошло несоответствие. Стандартное сообщение об ошибке таких данных не предоставляет, но можно программно получить объект ИнформацияОбОшибке(), у него есть свойство Причина. При ошибке XDTO там будет еще один объект ИнформацияОбОшибке().

    Если обойти их все рекурсивно, то дойдем до самого нижнего ИнформацияОбОшибке(), где будет сказано — какой именно узел XDTO выдал исключение. Если есть возможность, посмотрите конфигурацию БГУ, общий модуль Диагностика. Там как раз используется такой подход.

    Reply
  22. ksai

    Evil Beaver, сильно интересует дата выхода следующей статьи. Понимаю, что написание статей — занятие на чистом альтруизме, и пытаться определить конкретные сроки (и желательно ближайшие:) совсем непросто, но всё-таки?

    P.S. спасибо за полезную информацию в обеих заметках.

    Reply
  23. Evil Beaver

    В процессе. Сейчас горячая пора, годовой отчет. Времени в обрез, по ночам очень не хочется. Надеюсь на понимание.

    Reply
  24. pass_developer

    Надеюсь, что следующая статья выйдет скоро…

    Reply
  25. pass_developer

    Надеюсь,что следующая статья выйдет скоро…

    Reply
  26. daho

    Круто!! Очень доступно и толково написано. Что по сути то после нескольких опытов — с этой технологией не приходилось еще парится… но очень заинтересовало!

    Reply
  27. servs

    Автор, добавь (22) в статью.

    Reply
  28. hame1e00n

    Спасибо!!!)))

    Reply
  29. irishka77

    Спасибо, хорошо написано!Жду продолжения.

    Reply
  30. mvgfirst

    Я с XML недавно — статью начал читать из-за того что встала предо мной задача, разобрать XML-файлик от сторонней системы, и сейчас вижу что этот самый XDTO-пакет очень даже облегчит мне жизнь.

    Однако размышляя над его использованием вспомнил о своих мучениях по исследованию обработки «Обмен с сайтом», в которой разбор XML идет без использования XDTO фабрик. Хотя как по мне этобыло бы мега удолнее.

    Перед тем как ринутся в самостоятельное переписываение этой (достаточно типовой обработки) хотелось бы услышать мнения автора вчем недостатки применения фабрик XDTO в этой обработке и каковы по мнению автора мотивы отказа разработчиков 1С от использования фабрик XDTO в обмене?

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

    Reply
  31. Evil Beaver
    Перед тем как ринутся в самостоятельное переписываение этой (достаточно типовой обработки) хотелось бы услышать мнения автора вчем недостатки применения фабрик XDTO в этой обработке и каковы по мнению автора мотивы отказа разработчиков 1С от использования фабрик XDTO в обмене?

    К сожалению, я не в курсе. Ни о недостатках, ни тем более о причинах отказа 1С от XDTO в данном случае. Причина отказа, например, может быть в том, что на момент написания не было такой вещи, как XDTO, например, во времена 8.0. Это, конечно, только гипотеза 🙂

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

    Вполне возможно. Ищите готовую XML-схему для CommerceML, создавайте на ее основе фабрику (см. статью №3) и вперед.

    Reply
  32. mvgfirst

    (32)

    Ищите готовую XML-схему для CommerceML, создавайте на ее основе фабрику (см. статью №3) и вперед.

    ну поиск схемы много времени не занял )

    Схема CommerceML

    Буду разбираться

    Reply
  33. bek_bassar

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

    {Форма.Форма.Форма(8)}: Ошибка при вызове метода контекста (Тип)

    ПакетСообщений = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«urn:my-company/cms»),»MassagePackage»);

    по причине:

    Несоответствие типов (параметр номер ‘2’)

    я как понял с MassagePackage что то не то. Где корать?

    Reply
  34. a-novoselov

    (0) Платформа 8.2.18.61

    Приведенный в статье код не заработал. Пришлось изменить на:

    ПакетСообщений = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«urn:my-company/cms», «Package»));
    
    Для ш = 1 по 20 Цикл
    
    Сообщение = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«urn:my-company/cms», «Message»));
    
    Сообщение.number = ш;
    Сообщение.date = ТекущаяДата();
    Сообщение.text = «Купите дубленку»;
    
    ПакетСообщений.MessageList.Добавить(Сообщение);
    
    Сообщение = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«urn:my-company/cms», «Message»));
    
    Сообщение.number = ш;
    Сообщение.date = ТекущаяДата();
    Сообщение.text = «Уран недорого»;
    
    ПакетСообщений.MessageList.Добавить(Сообщение);
    
    КонецЦикла;
    
    Запись = Новый ЗаписьXML;
    ИмяВрем = ПолучитьИмяВременногоФайла(«txt»);
    Запись.ОткрытьФайл(ИмяВрем);
    ФабрикаXDTO.ЗаписатьXML(Запись, ПакетСообщений);
    Запись.Закрыть();
    

    Показать

    При схеме:

    Reply
  35. a-novoselov

    (34) Смотри (35). Если изменить код, то будет работать. Нужно поименовать элементы списка в схеме, и добавлять через Пакет.ИмяЭлемента.Добавть(ЭлементXDTO);

    Reply
  36. tolyan_ekb

    (32)Как будет происходить запись, если в схеме тип «Message» сразу сделать подтипом «MessagePackage» и в нем прописать его атрибуты номер и дату?

    Reply
  37. MakcTLT63

    Спасибо. Отлично.

    Reply
  38. mumilkin

    А теперь, следите за руками!

    Огромное спасибо за описание этого бага/фичи!!!

    Reply
  39. Evil Beaver

    (39) mumilkin, не за что. Хотя это не баг. Это логичное поведение, если помнить, что объекты должны быть выстроены в единый граф. Один и тот же объект не может находиться в двух узлах дерева XML одновременно.

    Reply
  40. lesenoklenok

    Спасибо за интересный материал.

    Reply
  41. check2

    (35) a-novoselov, у меня и этот не заработал.

    ФабрикаXDTO.Тип(«urn:my-company/cms»,»Package») возвращает Неопределено.

    1С:Предприятие 8.2 (8.2.18.82)

    Reply
  42. check2

    (35) a-novoselov, Надо бы ещё отметить, что всё это работает, только если вы не на клиенте управляемой формы. В обычной форме или на сервере всё идёт на ура. Именно по этому у меня не работало и возвращало Неопределено.

    Reply
  43. zakov

    В БСП в подсистеме «Контактная информация» используется XDTO, можно там глянуть пример необычного варианта использования технологии… Спасибо за статью! Хотелось бы конечно больше практики и отображение результата, но все думаю понимают, что это не вместишь в краткую статью… Статьи прежде всего ценны для изучения фундаментальных основ, все очень доступно…

    Reply
  44. Anton64

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

    ПространствоИмен = «url:my-company»;
    ТипОбъекта =  ФабрикаXDTO.Тип(ПространствоИмен, «MessagePackage»);
    ПакетСообщений = ФабрикаXDTO.Создать(ТипОбъекта);
    
    //Сообщения — это табличная часть обработки
    Для Каждого Адресат Из Сообщения Цикл
    
    Сообщение = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«url:my-company»,»Message»));
    
    Сообщение.number = Адресат.НомерСтроки;
    Сообщение.date = ТекущаяДата();
    Сообщение.__content = Адресат.ТекстСообщения;
    
    ПакетСообщений.Message.Добавить(Сообщение);
    
    КонецЦикла; 

    Показать

    Я так понял, что в пространстве имен, если это не http, не должно быть слэшей. ФабрикаXDTO.Тип и ФабрикаXDTO.Создать неправильно стоят запятые в статье. В ПакетСообщений надо указывать куда добавляешь, т.е. Message.

    Reply
  45. ::Green::

    Опечатки в статье:

    1)

    Есть:

    ПакетСообщений = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«urn:my-company/cms»),»MessagePackage»);

    Надо:

    ПакетСообщений = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«urn:my-company/cms»,»MessagePackage»));

    2)

    Есть:

    Сообщение = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«urn:my-company/cms»),»Message»);

    Надо:

    Сообщение = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«urn:my-company/cms»,»Message»));

    3)

    Есть:

    ПакетСообщений.Добавить(Сообщение);

    Надо:

    ПакетСообщений.Message.Добавить(Сообщение);

    Результат в части «А теперь следите за руками!» дал совсем другой результат от описанного автором:

    Код: (привязан по событию к кнопке)

    Процедура КнопкаСпамНажатие(Элемент)
    
    ПакетСообщений = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«urn:my-company/cms», «MessagePackage»));
    
    Сообщение = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«urn:my-company/cms», «Message»));
    Сообщение.number = 1;
    Сообщение.date = ТекущаяДата();
    Сообщение.__content = «Первая строка»;
    ПакетСообщений.Message.Добавить(Сообщение);
    
    //Сообщение = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«urn:my-company/cms», «Message»));
    Сообщение.number = 2;
    Сообщение.date = ТекущаяДата();
    Сообщение.__content = «Вторая строка»;
    ПакетСообщений.Message.Добавить(Сообщение);
    
    //Сообщение = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«urn:my-company/cms», «Message»));
    Сообщение.number = 3;
    Сообщение.date = ТекущаяДата();
    Сообщение.__content = «Третья строка»;
    ПакетСообщений.Message.Добавить(Сообщение);
    
    Запись = Новый ЗаписьXML;
    Запись.ОткрытьФайл(«C:	est2.xml»);
    ФабрикаXDTO.ЗаписатьXML(Запись, ПакетСообщений);
    Запись.Закрыть();
    
    КонецПроцедуры

    Показать

    Результат: (файл C: est2.xml)

    MessagePackage xmlns=»urn:my-company/cms» xmlns:xs=»http://www.w3.org/2001/XMLSchema» xmlns:xsi=»http://www.w3.org/2001/XMLSchema-instance»>

    <Message number=»3″ date=»2014-08-06T19:34:41″>Третья строка</Message>

    <Message number=»3″ date=»2014-08-06T19:34:41″>Третья строка</Message>

    <Message number=»3″ date=»2014-08-06T19:34:41″>Третья строка</Message>

    </MessagePackage>

    Reply
  46. sanfoto

    (0)

    Message.__content ——- блин у меня не прокатывает,


    …………………
    МояФабрикаXDTO = СоздатьФабрикуXDTO(ИмяФайлаСхемы);
    СтруктурныйТип_XDTO = МояФабрикаXDTO.Тип(«Order_Kontur_EDI»,»eDIMessage»);
    ФайлXML = МояФабрикаXDTO.ПрочитатьXML(ЧтениеXML,СтруктурныйТип_XDTO);
    

    ФайлXML—— все почти корретно… но нету блин .__content

    пс:

    Кстати XSD файл схемы удобно создавать АВТОМАТИЧЕСКИ файликом от MS VisualStudioxsd.exe

    Reply
  47. sanfoto

    (46) ::Green::,

    насколько я понял ниже описанную строку надо добавлять ПЕРЕД КАЖДЫМ СООБЩЕНИЕМ!!

    Сообщение = ФабрикаXDTO.Создать(ФабрикаXDTO.Тип(«urn:my-company/cms», «Message»));
    Reply
  48. sanfoto

    (47) sanfoto,

    хм Ошибочка у меня вышла… я сформировал файликом от VisualStudio … схему и загрузил в 1С,

    но не обратил внимание что НЕТУ ТИПОВ, а есть только СВОЙСТВА))

    ИСПРАВИЛ это дело .. добавил ТИПЫ…. теперь не создается объект ((((

    {Форма.Форма.Форма(84)}: Ошибка при вызове метода контекста (ПрочитатьXML): Ошибка преобразования данных XDTO:

    Чтение объекта типа: {Order_Kontur_EDI}eDIMessage — [13,12]

    Проверка дополнительного свойства:

    форма: Элемент

    имя: interchangeHeader: Ошибка проверки данных XDTO:

    Структура объекта не соответствует типу: {Order_Kontur_EDI}eDIMessage

    Reply
  49. Evil Beaver

    (49) sanfoto, что я могу сказать: пилите, Шура, пилите) Ошибка «структура не соответствует типу» означает нарушение схемы XML. Примерно где-то в строке 13 файла XML, но это ориентировочная цифра, не всегда может быть точной. Файлы посмотреть ваши сейчас совсем времени нет. Покопайте, там полюбому где-то мелкая ошибка.

    Reply
  50. sanfoto

    (50)

    ладно зайдем с другого конца…. )))

    ФайлXML=ФабрикаXDTO.ПрочитатьXML(ЧтениеXML)

    читает файл и создает объект…. (есно не совсем корректно,

    <requestedQuantity unitOfMeasure=»PCE»>2.000</requestedQuantity>

    Выделенное красным в Прочитанном объекте…отсутствует напрочь…. остальное верно все. )

    вопрос:

    Можно как ни-буть выдрать схему(для ФибрикиXDTO) из «ФайлXML=ФабрикаXDTO.ПрочитатьXML(ЧтениеXML)» ?

    Reply
  51. sanfoto

    (51)

    пока получилось только путем изменения исходной строки… но это считаю неверным путем))

    <requestedQuantity unitOfMeasure=»PCE»>2.000</requestedQuantity>
    /// меняем на понятную для 1с
    <requestedQuantity> <unitOfMeasure>»PCE»</unitOfMeasure> <body>2.000</body> </requestedQuantity>
    
    Reply
  52. sanfoto

    (50)

    я понял наконец то))), что в ПакетXDTO надо навставлять НУЖНЫЕ «Директивы импорта»- для проставки НУЖНЫХ типов (например добавил «http://v8.1c.ru/8.1/data/core»)

    ———————

    {Форма.Форма1.Форма(79)}: Ошибка при вызове метода контекста (ПрочитатьXML): Ошибка преобразования данных XDTO:

    Чтение объекта типа: {Order_Kontur_EDI}eDIMessage — [13,12]

    Проверка свойства ‘id’:

    форма: Атрибут

    имя: id

    тип: {http://v8.1c.ru/8.1/data/core}LocalStringItemType: Ошибка преобразования данных XDTO:

    Значение: ecf486b0-0614-4b83-9fde-5947ce407b06 Тип: {http://v8.1c.ru/8.1/data/core}LocalStringItemType — [13,12]

    наконец то хоть что-то прочиталось используя схему МоегоПакетаXDTO…. хоть и вылетело в ошибку.. но прочитало!!!! )))

    Reply
  53. sanfoto

    (0)

    короче ну их нафиг эти схемы… несколько дней попыток и я плюнул))

    прочитал недостающие значения в массив из ЧтениеXML, а остальное нормально и в «ФабрикаXDTO.ПрочитатьXML(ЧтениеXML)»

       ЧтениеXML. ОткрытьФайл(ИмяФайла);
    //////////////+ т.к. ОдинЦе не читало в ФабрикеXDTO значения «requestedQuantity»
    requestedQuantity = Новый Массив;
    Пока ЧтениеXML.Прочитать() Цикл
    Если ЧтениеXML.Имя  = «requestedQuantity» Тогда
    ЧтениеXML.Прочитать();
    requestedQuantity.Добавить(ЧтениеXML.Значение);
    ЧтениеXML.Прочитать();
    КонецЕсли;
    КонецЦикла;
    //////////////- т.к. ОдинЦе не читало в ФабрикеXDTO значения «requestedQuantity»
    ЧтениеXML. ОткрытьФайл(ИмяФайла);
    ФайлXML = ФабрикаXDTO.ПрочитатьXML(ЧтениеXML) ;

    Показать

    Reply
  54. sanfoto

    (54) sanfoto, (0) Evil Beaver

    таки я правильно СХЕМЫ делал…. ошибка была не в самой СХЕМЕ))

    оказывается надо в ИСХОДНОМ XML в открытие первого тэга ВПИХНУТЬ имя Пространства имен ФабрикиXDTO

    УРРА теперь и Тэги читаются Значения «__Content» и могу сам создавать XML файлы)), правда перед записью удалять надо пространство имен))

     СтрокаXML = СтрЗаменить(СтрокаXML, «<eDIMessage», «<eDIMessage xmlns=»»RECADV_Kontur»» «);
    ЧтениеXML = Новый  ЧтениеXML;
    ЧтениеXML.УстановитьСтроку(СтрокаXML);
    
    ТипacceptedQuantity = ФабрикаXDTO.Тип(«RECADV_Kontur», «eDIMessage»);
    СвояФабрика = ФабрикаXDTO.ПрочитатьXML(ЧтениеXML,ТипacceptedQuantity);

    Помогла публикация http://infostart.ru/public/311011/

    Reply
  55. Alexei_fox

    Как с помощью XDTO получить вот такую строку в xml ? <Картинка Описание=»Описание»>путь к картинки относительно xml файла.jpg</Картинка>

    Так то не проблема !!!

    <Картинка>

    <Описание>import_files/88/8868f46e-9d44-11e4-acb8-001e90f93bad_6098c20e-a850-11e4-85dc-001e90f93bad.jpeg</Описание>

    </Картинка>

    А разработчик приемника хочет именно <Картинка Описание=»Описание»>путь к картинки относительно xml файла.jpg</Картинка>

    Есть мысли у кого ?

    Reply
  56. Evil Beaver

    (56) Alexei_fox, создаете тип «Картинка», унаследованный от типа xs:string. Данному типу задаете атрибут «Описание».

    В XDTO текстовый узел будет называться __content. (перечитайте статью, там как раз это написано)

    Reply
  57. Alexei_fox

    (57) Ога — спасибо , разобрался !

    Reply
  58. crosby

    (46) ::Green::, зачем же Вы в исходном коде закомментировали строки создание объектов типа «message»? Вот у вас и лезет везде только последнее сообщение, о чем как раз автор и говорил! ))

    Reply
  59. veiuper

    Благодарю за серию статей.

    Может подскажете: как при записи XDTO объекта избавиться от добавления в xml файл атрибутов пространства имен (xmlns, xmlns:xs, xmlns:xsi)?

    Reply
  60. Evil Beaver

    (60) veiuper, никак. Они нужны же. А зачем вам от них избавляться?

    Reply
  61. veiuper

    (61) Делаю выгрузку в госреестры из 1С для медицинских организаций. Теги должны точно соответствовать приказу, а точнее быть без атрибутов. Удалить в принципе не проблема, просто подумал есть свойство которого я не вижу…

    Reply
  62. Evil Beaver

    (62) veiuper, теги не должны мешать чтению XML. Я, конечно, допускаю, что на стороне госорганизации чтение XML делается посимвольно, утилитой, которую писал школьник на делфи, но, скорее всего, там все же промышленный парсер, которому это не мешает.

    Reply
  63. veiuper

    (63) да просто в приказе однозначно сформулирована позиция по этому поводу. При наличии атрибутов при сдаче данного конкретного реестра случаев оказания медицинской помощи не будет пройден первый этап форматно-логического контроля на стороне сервера госорганизации. Скорее всего вы правы, что это не помешает чтению, но позиция однозначная и экспериментировать, а потом «краснеть» не хочется 🙂

    Или сказать по другому — недостаток опыта в сдаче реестров госотчетности и не знание на текущий момент сервисов для «первичного тестирования» выгрузки (если таковые имеются) накладывают подобные ограничения.

    Reply
  64. Hubbitus

    Никак не могу понять, как 1С заставить правильно трактовать предоставленный WSDL, и вместо дефолтных нэймспейсов типа:

    <m:code>upsert</m:code>
    <m:context>qwerty</m:context>
    

    делать (пробелы в теге вставлены просто чтобы не слетало форматирование):

    < code>upsert</code >
    < context>qwerty</context >
    

    для типов {http://www.w3.org/2001/XMLSchema}string?

    Подробный вопрос с WSDL и кодом есть на форуме мисты — http://www.forum.mista.ru/topic.php?id=778870

    Буду очень благодарен за ответ.

    Reply
  65. oksana.krokhina

    Добрый день! Есть xml-схема,файл (во вложении). Схему импортирую в 1с, все ок. В файле могут встречаться элементы такого вида:

    <param name=»Бренд»>Sols</param>

    <param name=»Размер экрана» unit=»дюйм»>27</param>

    Так вот, сделала также как в вашей статье, но при чтении файла не могу добраться до текстового значения элемента «param» (реквизит «__content»). Получаю только значения атрибутов:

    Как получить помимо имя параметра его значение? Т.е. не только «Бренд», но и «Sols»

    Заранее спасибо!

    Reply
  66. AlX0id

    (66)

    Полагаю, создать свойство в типе param, у которого поставить форму Текст. Ну если еще сами не разобрались, конечно %)

    Reply
  67. mvxyz

    Хорошие статьи. Спасибо автору за работу! Помогли понять основы.

    Reply
  68. oleganatolievich

    Спасибо за статьи.

    Но есть вопрос — если нужно выгружать только ссылку на свойство объекта, а не целый объект. Как это сделать — указывать в типе UID, а выгружать объекты предварительно самому?

    Reply
  69. Evil Beaver

    (69) Раскройте мысль, пожалуйста. Не совсем понятно, что нужно сделать

    Reply
  70. oleganatolievich

    (70) я сделал свою XDTO-схему, выгрузил номенклатуру, все ок. в выгруженном файле json, в свойствах объекта номенклатуры каждый раз выгружается единица измерения как объект, то есть:

    {

    «ID»: «746283f6-2399-11e7-8516-f832e486c9b0»,

    «FullPath»: «1 (Готовая продукция 43 счет)»,

    «Code»: «00-00007771»,

    «StockNumber»: «КЕ»,

    «Name»: «Котлеты от енота»,

    «ItemType»: «Товар»,

    «MeasuringUnit»: {

    «ID»: «39e33be4-5d60-11e6-845b-f832e486c9b0»,

    «Code»: «796 «,

    «Name»: «шт»

    },

    «WeightUsage»: false,

    «Weight»: «0»,

    «VolumeUsage»: false,

    «Volume»: «0»,

    «Individual»: false,

    «Dimensions»: {

    «ID»: «751c4471-9eb7-11e5-8e4a-0016e6d8441f»,

    «Code»: «000001161»,

    «Name»: «200×200 мм»,

    «FirstDimension»: «200»,

    «SecondDimension»: «200»

    },

    «BasicMaterial»: {

    «ID»: «39e9aa37-73fc-11e6-8473-f832e486c9b0»,

    «Code»: «000000012»,

    «Name»: «Мясо»,

    «FullName»: «Мясо»

    }

    }

    а надо

    {

    «ID»: «746283f6-2399-11e7-8516-f832e486c9b0»,

    «FullPath»: «1 (Готовая продукция 43 счет)»,

    «Code»: «00-00007771»,

    «StockNumber»: «КЕ»,

    «Name»: «Котлеты от енота»,

    «ItemType»: «Товар»,

    «MeasuringUnit»: «39e33be4-5d60-11e6-845b-f832e486c9b0»,

    «WeightUsage»: false,

    «Weight»: «0»,

    «VolumeUsage»: false,

    «Volume»: «0»,

    «Individual»: false,

    «Dimensions»: «751c4471-9eb7-11e5-8e4a-0016e6d8441f»,

    «BasicMaterial»: «39e9aa37-73fc-11e6-8473-f832e486c9b0»

    }

    Reply
  71. Evil Beaver

    JSON-воплощение XDTO я не пробовал ни разу. Весьма вероятно там есть и ошибки, и какие-то неизвестные мне параметры.

    Навскидку предположу, что вы сериализуете не ЕдиницаИзмеренияСсылка, а ЕдиницаИзмеренияОбъект.

    Reply
  72. oleganatolievich

    (72) сериализую объект XDTO, то есть создаю объект XDTO «ЕдиницаИзмерения», заполняю, и присваиваю в поле объекта «Номенклатура», полученный результат выгружаю в JSON. а ссылку во что вывести, в 36-символьную строку? так надо до этого выгрузить объект чтобы найти его по ссылке.

    Reply
  73. Evil Beaver

    (73)шта?? Можно кусок кода?

    Reply
  74. websamson

    Приведенный пример кода у меня не заработал. Сделал так:

    ТипПакетСообщений = ФабрикаXDTO.Тип(«urn:my-company/cms», «MessagePackage»);
    ПакетСообщений = ФабрикаXDTO.Создать(ТипПакетСообщений);
    
    СообщениеТип = ФабрикаXDTO.Тип(«urn:my-company/cms», «Message»);
    
    лСообщение = ФабрикаXDTO.Создать(СообщениеТип);
    лСообщение.number = «111»;
    лСообщение.date = ТекущаяДата();
    лСообщение.__content = «тест 111»;
    ПакетСообщений.Message.Добавить(лСообщение);
    
    лСообщение = ФабрикаXDTO.Создать(СообщениеТип);
    лСообщение.number = «222»;
    лСообщение.date = ТекущаяДата();
    лСообщение.__content = «тест 222»;
    ПакетСообщений.Message.Добавить(лСообщение);
    
    ПараметрыЗаписиXML = Новый ПараметрыЗаписиXML(«UTF-8», «1.0», Ложь);
    МойXML = Новый ЗаписьXML;
    ИмяФайла = «G:1CBasesXDTOout.xml»;
    МойXML.ОткрытьФайл(ИмяФайла, ПараметрыЗаписиXML);
    МойXML.ЗаписатьОбъявлениеXML();
    ФабрикаXDTO.ЗаписатьXML(МойXML, ПакетСообщений);
    МойXML.Закрыть();
    

    Показать

    Reply
  75. Evil Beaver
    Приведенный пример кода у меня не заработал

    А как именно он у вас не заработал? Разверзлась геена, вышел сотона и зохавал компьютер?

    Reply
  76. websamson

    (76)

    А как именно он у вас не заработал?

    Неверный синтаксис:

    ПакетСообщений.Добавить(Сообщение);

    а должно быть

    ПакетСообщений.Message.Добавить(Сообщение);
    Reply
  77. Evil Beaver

    (77) Спасибо, исправил!

    Reply
  78. dimasts

    Не могу понять, как заставить фабрику прочитать значение из строки:

    <Контрагент xmlns:xsi=»http://www.w3.org/2001/XMLSchema-instance» xsi:type=»CatalogRef.Контрагенты»>3722b978-d17a-11e5-89f0-001fc663b5b0</Контрагент>

    Все объекты без проблем читаются методом = ФабрикаXDTO.ПрочитатьXML(ЧтениеXML)

    и только контрагент имеет один атрибут type со значением CatalogRef.Контрагенты, куда девается ссылка?

    Пакеты xdto вообще не использую, так как все объекты нормально читаются, но походу надо создать маленький пакет специально для этой строки.

    Подскажите пожалуйста, как должен выглядеть этот микро-пакет или надо всё-таки создавать огромный пакет для всех объектов?

    Reply
  79. dimasts
    Reply
  80. Evil Beaver

    (79) Пакет создавать необязательно. Более того, такой XML лучше считывать глобальным методом ПрочитатьXML, а не фабрикой.

    Reply
  81. dimasts

    (81) У меня объекты по другому именуются, по-этому ПрочитатьXML не подойдет. Всё удалось прочитать, но остался один вопрос для шлифовки навыка так сказать: Ссылка на форум

    Если есть предложения буду благодарен

    Reply
  82. su_mai

    Лучше поздно чем никогда… Андрей, надо не «кракозябла», а «кракозябра»… 🙂

    Reply
  83. su_mai

    Очепятка…

    Теперь элемент Message может повторяться более в пакете более 1 раза.

    В XDTO такой элемнет будет не просто свойством, а СпискомXDTO.

    Reply
  84. maxim33

    В файле прикреплен ТипОбъекта, этот тип у свойства kind другого ТипаОбъекта. Тип «Смешанный». Как этому типу установить Текст, свойство с формой ФормаXML.Текст отсутствует у этого типа. Нужно заполнить этот параметр для вызова web сервиса. Т.е. в запросе должно выглядеть вот так:

    <xdms:kind >Письмо подразделения</xdms:kind>

    Как возможно добиться этого?

    Reply
  85. redtram

    Комрады, измаялся весь, не могу создать схему XDTO годную.

    Задача: преобразовать JSON в xdto с помощью ФабрикаXDTO.ПрочитатьJSON.

    Как в схеме XDTO описать массивы JSON вида:

    [
    {
    «offices»: [
    «8340», «8341»
    ]
    }
    ]

    (тут проблема с тем что внутри массива просто SimpleType неименованный)

    и

    «deliveryAddress»: {
    «»: null
    }

    (тут проблема с тем что имени у элемента ComlexType-а нет 🙁 )

    Reply
  86. koln

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

    Reply
  87. vlhown

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

    Никто не знает, как лечить?

    Reply
  88. stentor123

    Как правильно задать в фабрике XDTO подобный тип объекта? Кто-то сталкивался. Элемент с атрибутами.

    <error code=»124″>Неправильный номер телефона: +7999999999999</error>

    Reply
  89. Evil Beaver

    (89) тип ErrorMessage или какое угодно другое имя. Внутри свойство code с типом string и представлением «Атрибут». Далее свойство «message» с типом string и преставлением «Текст»

    Все, тип готов. Осталось разместить его в элемент с именем error и указанный кусок XML будет готов.

    Reply

Leave a Comment

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