Общие сведения об обмене данными
Общие сведения об обмене данными Механизмы обмена данными «1С: Предприятия» позволяют органи- зовывать обмен информацией, хранимой в базе данных, с другими программными системами. В качестве таких систем могут выступать как другие информаци- онные базы «1С: Предприятия» (имеющие аналогичную или отличаю- щуюся конфигурацию), так и программные системы, не основанные на «1С: Предприятии». Такая гибкость обмена данными достигается за счет того, что средства обмена данными «1С: Предприятия» могут использоваться в различных комбинациях. Кроме этого, формат обмена данными основан на языке XML, являющимся на сегодняшний день общепри- нятым средством представления данных. К механизмам обмена данными могут быть отнесены: Планы обмена, XML-сериализация, Средства чтения и записи документов XML. В общем случае схема взаимодействия этих трех составляющих может быть представлена следующим образом (рис. 24. 1). Рис. 24. 1. Схема взаимодействия механизмов обмена данными При помощи планов обмена мы получаем информацию о том, какие элементы данных были изменены и в какой узел обмена их необхо- димо передать. Это возможно благодаря тому, что планы обмена содержат механизм регистрации изменений. Информация об измененных данных пере- носится с помощью сообщений, инфраструктура которых также поддерживается планами обмена. XML-сериализация позволяет преобразовать объект «1С: Пред- приятия» в последовательность данных, представленных в формате XML. Кроме этого, XML-сериализация выполняет и обратное преоб- разование – преобразует последовательность данных формата XML в объект «1С: Предприятия», при условии что имеется соответству- ющий тип «1С: Предприятия».
Запись и чтение документов XML обеспечивают запись/чтение доку- ментов формата XML из встроенного языка. При реализации алгоритма обмена данными перечисленные механизмы могут быть использованы как все вместе, так и в различной комбинации. В каждом конкретном случае разра- ботчик решает эту задачу самостоятельно. В примере, приведенном в этой книге, мы используем все эти три механизма. Поэтому прежде чем перейти непосредственно к написанию кода, познакомимся с каждым из них подробнее.
Что такое план обмена Для того чтобы существовала возможность обмена какими-либо данными с кем-либо, необходимо некоторым образом идентифициро- вать тех, с кем мы будем обмениваться, и для каждого из них описать перечень обмена. Обе эти задачи позволяет решать объект конфигу- рации План обмена. Подобно тому, как элементами данных справочника являются элементы справочника, элементами данных плана обмена являются узлы плана обмена. Каждый узел идентифицирует участника обмена по данному плану обмена. Кроме этого, в каждом плане обмена всегда существует один предопределенный узел, идентифицирующий данную информаци- онную базу. В одной конфигурации может существовать несколько планов обмена. Каждый план обмена определяет набор данных, которым будет производиться обмен в рамках данного плана, и сам механизм этого обмена. Наличие нескольких планов обмена может потребоваться, если с разными узлами ведется обмен разным составом данных, или когда схема организации обмена с одними узлами отличается от схемы организации обмена с другими узлами.
УзнАй больше! О структуре объектов встроенного языка, предназначенных для работы с планом обмена, можно прочитать в разделе «Краткий справочник разработчика. Планы обмена» на стр. 941. В обмене данными могут участвовать:
объекты базы данных: элементы справочников, документы и т. д., необъектные данные: наборы записей регистров, последователь- ностей, константы, специальный объект встроенного языка – УдалениеОбъекта. Для упрощения изложения в дальнейшем будем называть эти элементы информационных структур объектами обмена. Разработчик имеет возможность определить состав каждого плана обмена, указав объекты конфигурации, данные которых должны участвовать в обмене по данному плану. При описании состава данных плана обмена разработчик имеет возможность указать для каждого типа объектов признак Автореги- страция. Этот признак определяет, каким образом план обмена будет отслеживать изменения данных. Возможность отслеживать изменения данных реализована в плане обмена за счет использования механизма регистрации изменений. Работа этого механизма базируется на том, что каждый из объектов обмена имеет свойство ОбменДанными, с помощью которого можно указать, для каких узлов необходимо производить регистрацию изменений этого объекта. Любые изменения объекта обмена сводятся в конечном итоге к записи или удалению объекта обмена. Механизм регистрации изменений анализирует события записи и удаления объектов обмена и на основании параметров обмена данными, содер- жащихся в каждом из объектов обмена, формирует записи реги- страции изменений. Следует отметить, что свойство ОбменДанными не хранится в базе данных, а используется только во время записи объекта обмена. Так вот, признак Авторегистрация, устанавливаемый при указании состава данных плана обмена, позволяет указать, что параметры обмена данными будут формироваться каждый раз самим меха- низмом регистрации изменений на основании информации, содержа- щейся в плане обмена. После автоматического заполнения параметров обмена разработчик все же имеет возможность внести изменения в сформированные таким образом параметры. Для этого следует использовать обра- ботчики событий объектов, участвующих в обмене, – ПередЗа- писью и ПередУдалением, в которых можно модифицировать список узлов-получателей (то есть тех узлов, для которых регистрируются изменения).
Кроме этого, существует возможность отключить авторегистрацию изменений, и тогда параметры обмена данными нужно будет форми- ровать полностью средствами встроенного языка. Гипотетически это можно делать в любом фрагменте кода, но для того, чтобы конфи- гурация была легко читаема, рекомендуется использовать все те же обработчики событий ПередЗаписью и ПередУдалением. В этом случае код формирования параметров обмена данными будет сосре- доточен в логически понятных точках, а не разбросан по всей конфи- гурации. Итак, как мы теперь знаем, при записи и удалении объектов обмена план обмена формирует записи регистрации изменений. Записи реги- страции изменений хранятся в таблицах регистрации изменений, причем для каждого объекта обмена ведется своя таблица. При изменении объекта обмена в таблице регистрации изменений создается столько записей, сколько узлов-получателей указано в пара- метрах обмена данными у объекта обмена. Каждая запись при этом будет хранить ссылку на свой узел-получатель. Таблицы регистрации изменений создаются лишь в том случае, если соответствующий объект метаданных указан в составе хотя бы одного плана обмена. Кроме ссылки на узел обмена, для которого регистрируются изменения, каждая запись таблицы регистрации изменений хранит также номер сообщения, в котором изменение было передано в первый раз в этот узел. До тех пор, пока сообщение не будет передано в первый раз, это поле хранит Null. Сообщение с точки зрения плана обмена – это единица обмена инфор- мацией. Поэтому одной из важнейших составляющих плана обмена, помимо службы регистрации изменений, является инфраструктура сообщений. Поскольку сообщения передаются в рамках плана обмена от одного узла к другому, каждое сообщение точно ассоциировано с планом обмена, имеет уникальный номер и одного отправителя и получа- теля. За нумерацию сообщений отвечает инфраструктура сообщений. Благодаря этому записи регистрации изменений и имеют возмож- ность хранить номера сообщений, в которых эти изменения были переданы первый раз. Инфраструктура сообщений позволяет также получать подтверж- дения от узла-получателя о приеме сообщений. Такое подтверждение содержится в каждом сообщении, приходящем от узла-получателя в виде номера последнего принятого сообщения. Впоследствии, проанализировав номер последнего принятого сообщения и номера сообщений, содержащиеся в записях реги- страции изменений, разработчик может удалить записи регистрации изменений, прием которых подтвержден получателем.
Воспользуйтесь поиском по сайту: ©2015 - 2024 megalektsii.ru Все авторские права принадлежат авторам лекционных материалов. Обратная связь с нами...
|