Работа с COM-объектом в 1С (v8.2)

06.08.13

Разработка - Механизмы платформы 1С

Цель публикации: Дать начальное представление о работе с COM-объектом через COM-соединение и привести пример его использования в 1С (v8.2).

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
Пример работы с COM-объектом
.epf 8,88Kb
41 2 500 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Вы можете заказать платную доработку или адаптацию этой разработки под вашу конфигурацию на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

Для организации доступа к данным 1С:Предприятие 8 через COM-соединение выполняется следующая последовательность действий:

  1. создается COM-объект с идентификатором V82.COMConnector:
    COMОбъект = Новый COMОбъект("V82.COMConnector");
     
  2. инициализируется строка соединения с информационной базой:
    Если ФайловаяИБ Тогда
    	ПутьКБазе = "File="""+ СокрЛП(КаталогИБ) +""";";
    Иначе
    
    	ПутьКБазе = "srvr="""+ СокрЛП(КластерСерверов) +""";"+
               	   "ref=""" + СокрЛП(ИмяИБВКластере)  +""";";	
    КонецЕсли;				
    				
    СтрокаСоединения = ПутьКБазе +
    		 "Usr="""+ СокрЛП(Пользователь) +""";"+
    		 "Pwd="""+ СокрЛП(Пароль) +""";";
  3. устанавливается внешнее соединение с информационной базой:
    V82 = COMОбъект.Connect(СтрокаСоединения);
  4. вызываются свойства и методы 1С:Предприятие 8 через созданный объект COM-cоединение:
    //Пример работы с константой
    V82.Константы.НомерВерсииКонфигурации.Получить();

 Код программы на 1С v8.2:

Перем V82;

Процедура УстановитьCOMСоединение(ФайловаяИБ) Экспорт
	
	Попытка
		//Создаем COM-объект с идентификатором V82.COMConnector
		COMОбъект = Новый COMОбъект("V82.COMConnector");
	Исключение
		Сообщить("Не удалось создать COM-объект!");	
		Возврат;
	КонецПопытки;

	//Инициализируем строку подключения к информационной базе:	
	Если ФайловаяИБ Тогда
		//Файловый вариант 
		ПутьКБазе = "File="""+ СокрЛП(КаталогИБ) +""";";
	Иначе
		//Серверных вариант	
		ПутьКБазе = "srvr="""+ СокрЛП(КластерСерверов) +""";"+
			   "ref=""" + СокрЛП(ИмяИБВКластере)  +""";";	
	КонецЕсли;
				
	СтрокаСоединения = ПутьКБазе +
			"Usr="""+ СокрЛП(Пользователь) +""";"+
			"Pwd="""+ СокрЛП(Пароль) +""";";	
						
	Попытка
		//Устанавливаем внешнее соединение с информационной базой через COM-соединение
		V82 = COMОбъект.Connect(СтрокаСоединения);
	Исключение
		Сообщить("Внешнее соединение не установлено!");	
		Возврат;
	КонецПопытки;
		
	РаботаСCOMОбъектом();
	
КонецПроцедуры

Процедура РаботаСCOMОбъектом()
	
	//Пример работы с константой
	НомерВерсииКонфигурации = V82.Константы.НомерВерсииКонфигурации.Получить();
	Сообщить("Номер версии конфигурации: " +НомерВерсииКонфигурации);
	
КонецПроцедуры

 
     
 

Вступайте в нашу телеграмм-группу Инфостарт

См. также

Механизмы платформы 1С Программист Бесплатно (free)

Разберем 15 мифов о работе платформы «1С:Предприятие 8» – как распространенных, так и малоизвестных. Начнем с классики: «Код, написанный в одну строку, работает быстрее, чем многострочный». Так ли это на самом деле?

16.07.2025    32256    TitanLuchs    108    

149

Механизмы платформы 1С Работа с интерфейсом Программист Стажер 1С:Предприятие 8 Бесплатно (free)

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

03.02.2025    17647    bayselonarrend    127    

68

Механизмы платформы 1С Программист 1С:Предприятие 8 Бесплатно (free)

В этой статье подробно рассматривается работа с JSON в XDTO в 1С:Предприятие. Вы узнаете, как сериализовать и десериализовать объекты XDTO в JSON, интегрировать 1С с веб-сервисами и API, а также корректно обрабатывать данные при обмене. Разбираются особенности работы с коллекциями, использование функций восстановления и частые ошибки при работе с JSON и XDTO.

30.01.2025    21934    user2122906    9    

66

Механизмы платформы 1С Файловый обмен (TXT, XML, DBF), FTP Программист 1С:Предприятие 8 Бесплатно (free)

Этот материал познакомит вас с механизмом XDTO (XML Data Transfer Objects) в 1С и научит эффективно использовать его возможности. Мы разберёмся, как работать с XML-схемами, создавать модели данных, манипулировать объектами XDTO, а также сериализовать и десериализовать их в XML. Вы узнаете, как использовать XDTO для интеграции с внешними системами, избегать типичных ошибок и оптимизировать код. К концу вы будете уверенно применять XDTO для решения сложных задач обмена данными и автоматизации процессов.

17.01.2025    38400    user2122906    12    

62

Механизмы платформы 1С WEB-интеграция Программист 1С:Предприятие 8 Бесплатно (free)

В платформе 8.3.27 появилась возможность использовать WebSocket-клиент. Давайте посмотрим, как это все устроено и чем оно нам полезно.

14.01.2025    33022    dsdred    106    

148

Механизмы платформы 1С Программист Стажер 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Эта небольшая статья - некоторого рода шпаргалка по файловым потокам: как и зачем с ними работать, какие преимущества это дает.

23.06.2024    28894    bayselonarrend    22    

177

Механизмы платформы 1С Программист Стажер 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Пример использования «Сервисов интеграции» без подключения к Шине и без обменов.

13.03.2024    15641    dsdred    22    

87
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. PowerBoy 3500 07.08.13 06:08 Сейчас в теме
Подключение через com - соединение увидел, а вот работу с ним нет :(
2. Samarin 98 07.08.13 07:06 Сейчас в теме
Просьба к автору дополнить статью примерами запросов к базе-источнику и преобразованием результата запроса для использования на базе-приемнике. Привести примеры работы "НайтиПоКоду()" или "НайтиПоНаименованию()", с целью использования в базе-приемнике и с целью использования в качестве параметра запроса к базе-источнику.
Вот тогда было бы интересно почитать.
5. help1Ckr 07.08.13 10:58 Сейчас в теме
(2) Samarin, Поддерживаю
3. 1CGid 12 07.08.13 08:24 Сейчас в теме
Добрый день! Статья будет обязательно дополнена более полным описанием работы с Com-объектом. Первоначалньно планировал показать на простом примере - обращение к константе через созданный Com-объект, но увидел что этого не достаточно.
4. ZLENKO 398 07.08.13 10:24 Сейчас в теме
Вот еще полезная статья на родственную тему про кеширование COM соединения: http://infostart.ru/public/182414/
6. Yashazz 4917 07.08.13 11:35 Сейчас в теме
Баян несусветный. На ИС множество гораздо более полных и интересных статей, всем советую читать их, а не этот, пардон, ошмёток копипаста.

Автор, расскажи, как определить тип значения произвольной переменной, работая через com-соединение? )))
Degron; Жолтокнижниг; +2 Ответить
10. Жолтокнижниг 310 09.08.13 19:02 Сейчас в теме
(6) Yashazz, поддерживаю и поэтому "-"
7. almas 264 07.08.13 21:43 Сейчас в теме
8. sbr 08.08.13 14:01 Сейчас в теме
Вот плюс я все-таки поставил...
Просто потому, что буквально на днях позвонил мне мой старый товарищ (в 1С пишет уже лет 10) и спрашивает как правильно прописать строку соединения с SQL - базой.
Я ему сбросил строку соединения и заоодно вспомнилось, как сам долго подбирал кавычки в строке соединения.
Вот поэтому и плюс.
9. Yashazz 4917 08.08.13 15:54 Сейчас в теме
(8) Строку соединения вообще-то можно функцией встроенного языка получить да посмотреть.
Для отправки сообщения требуется регистрация/авторизация