Универсальный метод сериализации значений в XML для локальных баз 1С на любом типе клиента под платформы 8.2 и 8.3, а также 8.1 и 8.0

26.08.24

Интеграция - Файловый обмен (TXT, XML, DBF), FTP

Описаны способы сериализации данных со стороны 1С методов для всей линейки 1с 8.

В настоящее время со стороны 1С существуют 3 метода сериализации значений:

  1. Старый способ со времен 7.7.
  2. Метод XML - довольно распространенный. Причём как вариант через БСП с использованием XDTO (8.1 и новее) и без него для платформы 8.0.
  3. Метод JSON - начиная с 8.3.6. 

Однако, при знакомстве с мобильной платформой выяснились следующие проблемы: старые добрые функции для серилизации не работают - это ЗначениеИзВнутСтроки() и ЗначениеВоВнутСтроку(). Точнее их вообще нет здесь.

Так как при создании моей Консоли Запросов я использовал не только платформу 8.3, но и 8.2 - то единственным доступным вариантом в моем случае остался 2-й метод. 

 

Универсальная Сериализация через XML

Стандартно для этих целей существуют следующие функции из БСП: 

//  Строка - XML-строка.
//
Функция ЗначениеВСтрокуXML(Значение) Экспорт
	
	ЗаписьXML = Новый ЗаписьXML;
	ЗаписьXML.УстановитьСтроку();
	СериализаторXDTO.ЗаписатьXML(ЗаписьXML, Значение);
	Возврат ЗаписьXML.Закрыть();
КонецФункции

// Выполняет преобразование (десериализацию) XML-строки в значение.
// См. также ЗначениеВСтрокуXML.
//
// Параметры:
//  СтрокаXML - Строка - XML-строка, с сериализованным объектом..
//
// Возвращаемое значение:
//  Произвольный - значение, полученное из переданной XML-строки.
//
Функция ЗначениеИзСтрокиXML(СтрокаXML) Экспорт
	
	ЧтениеXML = Новый ЧтениеXML;
	ЧтениеXML.УстановитьСтроку(СтрокаXML);
		
	Значение=СериализаторXDTO.ПрочитатьXML(ЧтениеXML);
	Возврат Значение;
	
КонецФункции

Эти функции, взятые из БСП, - хорошие. Однако передать через них серьезные объекты (в моем случае это был тип данных РезультатЗапроса) без выгрузки или других танцев с бубном в рамках портирования консоли на мобильные платформы оказалось абсолютно невозможным, так как данные типы тип не сериализуются XDTO. 

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

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

Итоговые правки в код дают следующие функции:

// Преобразованы в могут быть любые объекты (дополнено через ХранилищеЗначения.
// См. также ЗначениеИзСтрокиXML.
//
// Параметры:
//  Значение - Произвольный - значение, которое необходимо сериализовать в XML-строку.
//
// Возвращаемое значение:
//  Строка - XML-строка.
//
Функция ЗначениеВСтрокуXML(Значение) Экспорт
	
	ЗаписьXML = Новый ЗаписьXML;
	ЗаписьXML.УстановитьСтроку();
    Если Значение=Тип("ХранилищеЗначения") Тогда
      //Сохраняем жизнь исходному типу - через оборачивание.
        ХранилищеЗначения=новый ХранилищеЗначения(Значение);
		СериализаторXDTO.ЗаписатьXML(ЗаписьXML, ХранилищеЗначения);
    иначе
       //Выполняем Сериализацию:
	   попытка
		  СериализаторXDTO.ЗаписатьXML(ЗаписьXML, Значение);
	   исключение
		 ХранилищеЗначения=новый ХранилищеЗначения(Значение);
		 СериализаторXDTO.ЗаписатьXML(ЗаписьXML, ХранилищеЗначения);
	   КонецПопытки;
    КонецЕсли;
	Возврат ЗаписьXML.Закрыть();
КонецФункции

// Выполняет преобразование (десериализацию) XML-строки в значение.
// См. также ЗначениеВСтрокуXML.
//
// Параметры:
//  СтрокаXML - Строка - XML-строка, с сериализованным объектом..
//
// Возвращаемое значение:
//  Произвольный - значение, полученное из переданной XML-строки.
//
Функция ЗначениеИзСтрокиXML(СтрокаXML) Экспорт
	
	ЧтениеXML = Новый ЧтениеXML;
	ЧтениеXML.УстановитьСтроку(СтрокаXML);	
	ХранилищеЗначение=СериализаторXDTO.ПрочитатьXML(ЧтениеXML);
    //Восстанавливаем значение из Хранилища:
	Если ХранилищеЗначение=Тип("ХранилищеЗначения") Тогда
		
		Возврат ХранилищеЗначение.Получить();

	иначе 
		Возврат ХранилищеЗначение;

	КонецЕсли;
	
КонецФункции

Если есть необходимость ввести универсальную функцию, которая совместима на компьютерных платформах со старым внутренним форматом 1С (мне понадобилось для работы с Консолью Запросов на Windows), тогда полученные универсальные функции:

Функция УниверсальнаяЗначениеВСтрокуВнутр(Значение) 
	
	Попытка
		
		
		возврат Вычислить("ЗначениеВСтрокуВнутр(Значение)");
		
	Исключение
		//Для мобильных приложений выполняем по правилам XMl-Функций, которые были переделаны:
		
		возврат ЗначениеВСтрокуXML(Значение);
		
		
	КонецПопытки;	
	
КонецФункции	


Функция УниверсальнаяЗначениеИзСтрокиВнутр(Значение) 
	
	Попытка
		
		возврат Вычислить("ЗначениеИзСтрокиВнутр(Значение)");
		
	Исключение
		//Для мобильных приложений выполняем по правилам XMl-Функций, которые были переделаны:
		
		возврат ЗначениеИзСтрокиXML(Значение);
				
	КонецПопытки;	
	
КонецФункции

Однако, если требуется поддержка и платформы 8.0 и мобильной платформы 8.3 (зачем прошу не спрашивать), включая многострадальный IOS (нет функции выполнить и вычислить),  то гораздо проще воспользоваться следующими функциями: 

//Для сложных типов данных - читаем через Хранилище Значения (метод 1с 8.0 и новее!!! - заменил БСП):
Функция ЗначениеВСтрокуXML(Значение) Экспорт
	
	возврат XMLСтрока(новый ХранилищеЗначения(Значение));
	
КонецФункции

Функция ЗначениеИзСтрокиXML(СтрокаXML) Экспорт
	
	возврат XMLЗначение(Тип("ХранилищеЗначения"),СтрокаXML).Получить();
	
КонецФункции

PS: приведенными функциями в пределах одной базы можно пользоваться на следующих платформах: 

  1. Компьютерные: 1С 8.2 и 1С 8.3 - Тонкий, Толстый, ВебКлиент. Для 1с 8.0 и 8.1 - толстый клиент и сервер.
  2. Для одной базы данных, можно использовать функции сериализации в XML посредством методов XMLСтрока и XMLЗначение, предварительно упаковав в Хранилище значений. Последнее необходимо для сохранения данных. Тем более, что это работает для всех платформ и видов соединений с данными (Сервер, ТолстыйКлиент, Мобильные серверные части)
  3. На мобильных платформах 8.3 можно использовать универсальные переделанные функции БСП для аналога внутренних значений.  

Тестировалось на платформах 8.2 и 8.3 для замены БСП функций. Режим совместимости с 8.1 не пострадал. Последние функции были проверены на платформе 1с 8.0.14.

 

ЗначениеВоВнутСтроку ЗначениеИзВнутСтроки мобильная платформа. XMLСтрока XMLЗначение. Платформа 1С V8.0

См. также

SALE! 20%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Россия Платные (руб)

Правила в универсальном формате обмена для ERP 2.5, КА 2.5, УТ 11.5, БП 3.0, Розница, УНФ, для последних версий конфигураций. Ссылки на другие конфигурации в описании публикации. Правила совместимы со всеми другими версиями конфигураций новыми и старыми, поддерживающими обмен и синхронизацию в формате EnterpriseData. Не требуется синхронного обновления правил после обновления другой конфигурации, участвующей в обмене. Типовой обмен через планы обмена кнопкой Синхронизация вручную или автоматически по расписанию, или вручную обработкой.

26280 22338 руб.

12.06.2017    141531    798    297    

419

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УПП 1.3 (1.3.234.x) и БП 3.0 (3.0.161.x). Правила подходят для версии ПРОФ и КОРП.

35000 руб.

15.12.2021    24028    169    51    

127

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 Оперативный учет 1С:Управление торговлей 10 Россия Управленческий учет Платные (руб)

Перенос данных из 1С:Управление торговлей 10.3 в 1С:Управление торговлей 11.5 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УТ 10.3 (10.3.88.x) и УТ 11.5 (11.5.19.x).

35000 руб.

23.07.2020    51273    228    69    

185

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 Сложные периодические расчеты 1С:Комплексная автоматизация 1.х 1С:Управление производственным предприятием 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет Платные (руб)

Правила переноса кадровых и расчетных данных и справочной информации из "1С:УПП1.3" или "1С:КА 1.1" в "1С:ЗУП 3.1 | Разработан в формате КД 2 (правила конвертации данных) | При выгрузке есть фильтр по организациям | Обновляется при выходе новых релизов 1С | Развитие алгоритмов | Расчетные документы переносятся в документ "Перенос данных" | Создаются документы "Начальная штатная расстановка" и "Начальная задолженность по зарплате", переносятся кадровые документы

55778 50200 руб.

29.10.2018    56210    59    105    

61

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена | Можно выполнить переход с УПП на БП 3 или запускать выгрузку данных за выбранный период времени | Переносятся документы, начальные остатки и вся справочная информация | Есть фильтр по организации и множество других параметров выгрузки | Поддерживается несколько сценариев работы: как первичный полный перенос, так и перенос только новых документов | Перенос данных возможен в "1С: Бухгалтерия 3.0" версии ПРОФ, КОРП или базовую | Переход с "1С: УПП1.3" / "1С:КА 1.1" на "1С:БП3.0" с помощью правил конвертации будет максимально комфортным! | Можно бесплатно проверить перенос на вашем сервере!

48278 43450 руб.

25.02.2015    171178    303    257    

378

SALE! 15%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 Платформа 1C v8.2 1С:Комплексная автоматизация 1.х 1С:Управление торговлей 10 1С:Управление производственным предприятием Россия Платные (руб)

Регулярный обмен, выгрузка, перенос из КА 1.1, УПП 1.3, УТ 10.3 для обмена с любыми конфигурациями, поддерживающими обмен в формате EnterpriseData (КД3) - БП 3.0, ERP, КА 2, УТ 11, Розница 2, УНФ 1.6 и другими. Правила для старых и доработанных конфигураций не требуют синхронного обновления и совместимы с новыми и будущими конфигурациями. Обмен по расписанию, через папку, FTP, почту.

15300 13005 руб.

18.02.2016    186886    589    509    

526

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из ERP в ЗУП 3 | из КА 2 в ЗУП | Готовые правила конвертации данных (КД 2) для переноса остатков, документов с движениями и справочной информации 3 | Есть перенос начальной задолженности по зарплате и начальной штатной расстановки на выбранную дату | Обороты за прошлые годы (данные для расчета среднего) переносятся свернуто в документ "Перенос данных" | Есть фильтр по организациям | Документы за текущий период переносятся сразу с движениями, поэтому не потребуется делать перерасчеты | Перенос можно проверить перед покупкой, обращайтесь!

53111 47800 руб.

03.12.2020    36595    94    66    

89

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Платные (руб)

Перенос данных из ERP в БП 3 | из КА 2 в БП 3 | из УТ 11 в БП 3 | из ЕРП в БП 3 | Сэкономьте время - используйте готовое решение для перехода! | Перенос разработан в формате КД 2 (правила конвертации данных) | Переносятся все возможные виды документов, начальных остатков и нормативно-справочная информация| Можно опционально выгружать каждую пару "номенклатура+характеристика" как отдельную номенклатуру | Есть выгрузка настроек счетов учета и зарплатных данных из ERP / КА 2 | Можно проверить на вашем сервере перед покупкой

55778 50200 руб.

15.04.2019    72099    180    150    

122
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Никулин Леонид 4 27.07.23 13:03 Сейчас в теме
В БСП:
Ведомость = ОбщегоНазначения.ЗначениеИзСтрокиXML(СтрокаXML); // ТЗ из XML строки
СтрокаXML = ОбщегоНазначения.ЗначениеВСтрокуXML(Ведомость); // ТЗ в XML строку
2. user1206119 90 27.07.23 13:38 Сейчас в теме
(1) Таблица значений может быть параметром серилизатора, а результат запроса, внешняя обработка нет. Их нужно помещать в хранилище значений предварительно. Поэтому БСП функционал с этими функциями мне не подошёл. Я таким образом перегоняю Результат Запроса.
3. user1206119 90 26.08.24 23:03 Сейчас в теме
(1) Добавил функции для более простой серилизации - протестировал их на 1с 8.0.14 - работают. На мобильной платформой нет проблем.
Оставьте свое сообщение