1с библиотека как работать
Всем привет! Данный материал посвящен дальнейшему описанию возможностей типовой поставляемой конфигурации для разработчиков "Библиотека стандартных подсистем" (БСП). В настоящей статье, я опишу часть "основ" библиотеки - базовый функционал общего назначения, который уже можно использовать (т.е мы ничего не придумываем сами, используем готовые решения и экономим собственное и чужое время) в любых конфигурациях, основанных на БСП.
В данной статье, я буду описывать и приводить примеры функций и процедур модуля общего назначения БСП, которые, на мой взгляд, наиболее полезны для разработчика и я, достаточно часто, применяю их в своей практике программирования.
В качестве платформы я использую 1С:Предприятие 8.3.17.1549 (64 бит) и последнюю конфигурацию Розница 2.3.5.32. В указанную конфигурацию встроена БСП 3.1.2.457 версии (отмечу, что не самая последняя, на момент написания статьи - последняя 3.1.3).
Итак, давайте перейдем к описанию:
Полезные функции и процедуры общего модуля БСП
Работа с данными в базе
Функция 1.1
ЗначенияРеквизитовОбъекта(Ссылка, Знач Реквизиты, ВыбратьРазрешенные = Ложь, КодЯзыка = Неопределено) Экспорт
Данная серверная функция позволяет получить выбранные реквизиты (Знач Реквизиты) по ссылке - Ссылка. Пример применения данной функции вот такой:
Очень удобно, когда ты можешь получить сразу необходимую структуру по любой ссылке в допустимой степени без использования запросов и дополнительного кода.
Функция 1.2
ЗначенияРеквизитовОбъектов(Ссылки, Знач Реквизиты, ВыбратьРазрешенные = Ложь) Экспорт
Более универсальная функция, повторяющая смысл предыдущей, но в качестве ссылок уже можно передавать массив. Пример такой:
Для "базовых вещей" данные функции очень даже применимы. В БСП есть рекомендация использовать именно эти функции, а не обращаться к реквизитам через точку.
Функция 1.3
ПроверитьПроведенностьДокументов(Знач Документы) Экспорт
Данная функция возвращает массив непроведенных документов. Если документы проведены - массив пустой. Пример использования:
Одна из удобных базовых функций для работы, на мой взгляд. В данном примере мне будет возвращен массив с 2 элементами, т.к. 2 документа из 3-х у меня не проведены.
Функция 1.4
ПровестиДокументы(Документы) Экспорт
Еще одна интересная функция, которая проводит документы, а так же возвращает массив документов с описанием ошибок, если не удалость провести:
Здесь, функция вернула мне массив такого содержания, где видно какой документ не удалось провести и почему:
Рис.1. Элементы массива содержат структуры с описанием ошибки и ссылки.
Функция 1.5
ЕстьСсылкиНаОбъект(Знач СсылкаИлиМассивСсылок, Знач ИскатьСредиСлужебныхОбъектов = Ложь) Экспорт
Данная функция осуществляет простую проверку - есть ли ссылки на объект или нет. Возвращает "истину" или "ложь".
Функция 1.6
МестаИспользования(Знач НаборСсылок, Знач АдресРезультата = "") Экспорт
Данная функция возвращает таблицу значений с указанием, где используется передаваемый объект:
Например, документ "Отчет о розничных продажах" имеет ссылку в документе "Выемка денежных средств из кассы ККМ", что показывает нам результат этот функции:
Рис.2. Строка таблицы значений с результатом использования Ссылки. Ссылка - Данные
Работа с окружением базы
Функция 2.1
ОписанияПодсистем() Экспорт
Данная функция возвращает массив структур, содержащий информацию о системах и стандартных библиотеках, включенных в конфигурацию (то же самое, что содержимое файла Версии библиотек.txt при поставки конфигурации. Например:
Рис.3. В конфигурацию включена подсистема маркировки 10.1.18.
Функция 2.2
ОбщиеПараметрыБазовойФункциональности() Экспорт
Данная функция возвращает структуру с настройками базовой функциональности конфигурации. Интересным содержанием структуры является такие как МинимальнаяВерсияПлатформы и РекомендуемыйОбъемОперативнойПамяти.
Обращение к функции вот так:
Функция 2.3
ИнформационнаяБазаФайловая(Знач СтрокаСоединенияИнформационнойБазы = "") Экспорт
Определяем является ли информационная база файловой (Истина) или серверной (Ложь).
Функция 2.4
ОперативнаяПамятьДоступнаяКлиентскомуПриложению() Экспорт
Данная функция возвращает объем оперативной памяти, которая доступна приложению (в гигабайтах). Вот у меня в системе доступно 3.9 гб:
Функция 2.5
РедакцияКонфигурации() Экспорт
Данная функция возвращает номер (строка) редакции конфигурации:
Функция 2.6
ЭтоWindowsКлиент() Экспорт
Данная функция возвращает Истина, если пользователь работает по windows на клиенте. Так же есть группа подобных функций, позволяющих определять где работает пользователь: ЭтоWindowsСервер(), ЭтоLinuxКлиент(), ЭтоLinuxСервер(), ЭтоMacOSКлиент(), ЭтоВебКлиент(), ЭтоМобильныйКлиент(), КлиентПодключенЧерезВебСервер(). Все функции работают через привилегированный режим.
Работа с датами
Функция 3.1
ПредставлениеЛокальнойДатыСоСмещением(ЛокальнаяДата) Экспорт
Данная функция возвращает дату со смещением по часовому поясу, в описании по формату "YYYY-MM-DDThh:mm:ssTZD" :
Функция 3.2
ИнтервалВремениСтрокой(ВремяНачала, ВремяОкончания = Неопределено) Экспорт
Полезная функция, возвращающая интервал времени строкой, в пример - вернет "1 день":
Функция 3.3
ТекущаяДатаПользователя(ИмяПользователя = Неопределено) Экспорт
Данная функция вернет текущую дату пользователя по его имени:
Заключение
Спасибо за прочтенный материал. Знаю, что в той или иной степени, на ресурсе уже были подобные статьи с описанием подобного функционала. Со своей стороны хочу отметить, что данная статья - это своего рода "моя индивидуальная выжимка собственного опыта", накопленного при работе с типовыми конфигурациями на основе БСП. Предполагаю, что данная статья-шпаргалка будет полезна как и мне (чтобы не забыть возможности), так и вам - "если что-то не знали" - пожалуйста, тут есть что узнать и запомнить.
Предыдущие материалы
Так же, я прошу посмотреть мои предыдущие статьи, посвященные базовым возможностям типовых конфигураций:
Специальные предложения
По собственному применению БСП, могу сказать что методы в ней последнее время очень быстро устаревают - такая тенденция.
В частности касается работы "длительных операций".
Напишу статью в дальнейшем по применению длительных операций.
После того как "ПолучитьНомерНаПечать" уехал в "НомерНаПечать" стараюсь не использовать как БСП, так и вообще разные типовые процедуры и функции конфигураций, становится себе дороже. user717534; user1346935; slicem; oninfostart; modestry; ybatiaev; AlkB; Yashazz; Serega-artem; Azamatex; surikateg; morin; zqzq; garik79; + 14 – Ответить (4) Тут как раз рецепт простой. Любой вызов типового модуля или объекта, нужно оборачивать в свой метод, и если функциональность переедет, то проблем не будет особых(4)Может выпустить надстройку над БСП (и другими типовыми библиотеками) - где разместить функциональность в небольшом количестве ) модулей (не 1С Совместимых, зато лаконичных) - так, чтобы минимизировать последующие переносы/удаления функций - а если таковые и будут - то делать обратную совместимость (с указанием obsolete и выводом таких вызовов в ж/р (для последующего выявления и исправления в коде), можно и спец инструмент добавить - анализирующий код на предмет вызовов таких obsolete (устаревших) функций).
Именовать модули можно достаточно лаконично и обобщённо. Я бы выделил несколько общих "классов" - и сосредоточил в них функциональность - как-будто это действительно классы-расширения (хелперы - как их ещё называют в других языках). В принципе - подключив расширения IDE и препроцессор можно было бы даже реализовать авто-привязку этих функций прям к исходным обеъктам (например к документу объекту/ссылке или к печатной форме: расширение IDE бы позволяло бы видеть эти функции именно в контексте объектов которым они привязаны (через точку_, ну а далее либо делать сразу подстановку нужного вызова из общего модуля, либо оставлять так как есть - а замену уже будет делать препроцессор - например при передаче из IDE в ИБ через агента-конфигуратора - как это делает EDT, просто тут возникает доп звено трансляции).
И так далее (вообще так модулей может набежать достаточно много - больше сотни - в лёгкую - но все они будут сжатыми представителями общей функциональности, и могут содержать достаточно много процедур - но все они - лишь переадресация в другие модули - где они уже будут иметь реализацию алгоритмов).
Отдельно нужен будет модуль для универсального вызова сервера (с общей функцией универсального вызова (с преобразованием типов при необходимости), в т.ч для удобного вызова на сервере функциональности из обработок).
Отдельно нужен будет модуль для универсального фонового вызова функции (с общей функцией универсального вызова (с преобразованием типов при необходимости), несмотря на то, что есть модуль "ФоновоеЗаданиеМенеджер", в т.ч для удобного вызова в фоне функциональности из обработок).
Отдельно нужен будет модуль для универсального внешнего вызова функции (с общей функцией универсального вызова как COM таки WS соединений, с кешированием соединений, с преобразованием типов при необходимости, несмотря на то, что есть модуль "ВнешниеСоединениеМенеджер").
Отдельно можно сделать модуль для универсального вызова функции внешней компоненты (с общей функцией универсального вызова, с кешированием внешних компонент, с преобразованием типов при необходимости, несмотря на то, что есть модуль "ВнешнияКомпонентаМенеджер", в т.ч для удобного вызова во внешнем контексте функциональности из обработок).
Отдельно нужен будет модуль для универсального кешированного вызова (с общей функцией универсального вызова, с преобразованием типов при необходимости, несмотря на то, что есть модуль "КешированиеМенеджер").
Это всё-чтобы не плодить кучу лишних модулей и сделать работу с данной функциональностью наиболее удобной!
А вот для привилегированных вызовов такой модуль делать не стоит - ибо это уже вопросы безопасности.
Можно всё это разбить даже на несколько отдельных частей - базовые и расширенные (устанавливаемые путём объединения конфигураций)
Внутри можно либо делать поддержку всех БСП (начиная с какой-то опр редакции - просто проверяя текущую редакцию и перенапрравляя вызов в нужный модуль стандартной библиотеки), либо делать скользящую поддержку (то есть для каждой версии БСП отдельно, но скорее тут тоже гибридно выйдет - например выпускать отельные библиотеки для подредакций БСП (3.0, 3.1, 3.2. ), а для релизов - осуществлять уже общую поддержку внутри всех вариантов).
Ну, как написал, это может быть единая библиотека (набор библиотек) не только для БСП но и для других стандартных библиотек. кстати, не обязательно, даже типовых - просто выпускать доп расширения (ставящиеся объединение конфигураций), которые будут соблюдать общий принцип именования пространства имён.
Так же можно делать модули с улучшенным функционалом - если сообщество напишет лучшие алгоритмы, чем будут в стандартных библиотеках - именовать переадресацию на их реализацию можно в таких общих модулях (устанавливаемых отдельно):
СтрокаМенеджерРасширение
СтрукутраМенеджерРасширение
Но это только для пересекающегося функционала.
И ещё - если в процессе эволюции БСП у функции меняется состав аргуменнтов
- то если в сторону расшироения - проблем нет - в переадресации дописываются новые необязательные аргументы
- если в сторону сокращения и/или изменения порядка - нужно стараться сохранить поддержку старого порядка - т.е. нужно будет проверять типы аргументов и перетасовывать их
- А вот если типы будут идентичны - тогда придётся выпускать проверять текущую версию БСП - которую задаст программист при инициализации библиотеки (а не версию из конфигурации) - если программист уже перевёл код на новую версию - то он изменит и эту версию. На переходный период - так же должны быть функции с заданной версией БСП в окончании - сначала можно будет переходить на них, потом их можно будет быстро найти заменить на без окончания-версии, когда версия БСП при инициализации сменится
Вообще тут много чего ещё можно придумать!
Например привнести поддержку элементов АОП - коли не типовые функции будут вызываться вместо типовых в самом низу иерархии вызовов (с последующей переадресацией) - то этими вызовами можно управлять более расширено!
Так же я, настоятельно бы, ввёл модуль
СобытияФормыМенеджер - через который бы осуществлял бы ручную "подписку" (и ручную инициация событий) для различных событий формы (на которые в платформе не возможно обобщённо подписаться).
Ну и вообще добавил ещё и общий модуль
СобытияМенеджер - для всех остальных событий, на которые тоже нельзя универсально подписаться (по сути - просто некоторые встроенные обработчики, но, не только платформенные - тут могут быть и БСП-шные функции)
Но, конечно, чтобы эти события заработали - их нужно будет интернировать в свои метаданные и в типовые модули тоже - для этого нужно будет сделать отдельную интеграционную конфигурацию - вставляющую код в типовой код (или какой-то отельный инструмент - обрабатывающий тексты модулей для такой вставки)
ну, а если уж совсем по-хорошему - то для функций такой библиотеки можно будет создать правильные описания (комментарии) и на их основе сгенерировать справку по использованию (а-ля синтаксиис-помошник) - которой ТАК НЕ ХВАТАЕТ для БСП (и других стандартных библиотек), в которой можно будет делать поиск (и видеть для каких версий платформы и БСП предназначена та или иная функциональность - и делать фильтр по этим версиям, и не только по версия - а например по подсистемам тоже).
Продукт позволяет автоматизировать рабочие процессы библиотеки, в зависимости от ее назначения, типа, состава фондов, может быть интегрирован с другими типовыми решениями фирмы "1С".
С помощью системы "1С:Библиотека" может быть автоматизирована деятельность библиотек разных назначений и типов:
- универсальных - муниципальных, областных, региональных;
- учреждений образования - школ, детских садов, колледжей, вузов;
- отраслевых - библиотек предприятий, компаний, заводов, больниц, научно-исследовательских институтов, военных частей;
- специальных - музыкальных, театральных, библиотек музеев и академий художеств и пр.;
- частных (домашних).
- Описание любых видов изданий, включая документы в электронном формате, аудио-, видео-, нотные, картографические, изоиздания и пр.
- Полная поддержка национального коммуникативного формата RUSMARC.
- Обеспечение контроля вводимых данных на их соответствие требованиям стандартов.
- Автоматическая индексация, на основе которой реализуется быстрый поиск по любым элементам библиографического описания и их сочетаниям.
- Возможность использовать любые графические материалы (изображения титульных листов, артефактов, страниц текста и т.д.).
- Экспорт/импорт данных в MARC-форматах.
- Хранение неограниченного количества библиографических записей.
- Поддержка процессов упорядоченного хранения и учета документов библиотеки любого формата в соответствии с ее типом и назначением.
- Обеспечение процессов движения фонда.
- Ведение индивидуального и суммарного учета документов (изданий) как по совокупному фонду библиотеки, так и по отдельным фондам (специализированным) с учетом специфики хранящихся в них изданий.
- Возможность вводить в учетные документы не только обязательные, но и факультативные показатели с учетом специфики конкретной библиотеки.
- Регламентирование и дифференцированный доступ к документам фонда для различных групп читателей.
- Быстрая идентификация читателей с помощью технологии штрихового кодирования читательских билетов.
- Дневник работы библиотеки.
- Удаленный доступ читателя к электронному каталогу и поиск изданий по любым элементам библиографического описания.
- Формирование электронной заявки по результатам поиска.
- Удаленный доступ к данным о наличии свободных физических экземпляров изданий в фондах библиотеки.
- Удаленный доступ читателя к своему формуляру.
- Контроль читателя за процессом исполнения сформированных заказов.
- Оповещение читателя о выполненных заказах и его задолженности.
Формирование и поддержка электронного библиотечного фонда
- Прикрепление к библиографическим записям электронного каталога произвольного количества электронных материалов (изданий в электронном формате)
- Поиск по содержимому электронных изданий
- Возможность прикрепления обложек
- Хранение и выдача читателю изданий в электронном формате
Cтатистика и отчетность
- КСУ
- Инвентарная книга
- Ведомость проверки фонда
- Партии физических экземпляров изданий
- Книговыдача
- Книгообеспеченность
- Статистический отчет
- Формирование стандартного набора документов и сопутствующих документов для карточного библиотечного каталога.
- Поддержка всех необходимых печатных форм в соответствии с типовыми инструкциями и методическими рекомендациями Министерства образования и науки РФ.
В программе предусмотрена выгрузка данных в конфигурацию "1С:Бухгалтерия государственного учреждения 8". Выгрузка осуществляется в xml-файл на уровне документов поступления и списания библиотечного фонда.
Свидетельство Национальной Службы развития системы форматов RUSMARCНовое в редакции 2.0 конфигурации "1С:Библиотека"
1. Реализована возможность переноса данных из конфигураций на платформе "1С:Предприятие 7.7": в новую редакцию включены файлы для переноса всех данных (включая каталог библиографических описаний, данные по движению фонда и движению читателей) из конфигураций на платформе 1С:Предприятие 7.7:
· 1С:Библиотека ВУЗа, редакция 3.02 (7.70.302);
· 1С:Библиотека Колледжа, редакция 2.03 (7.70.203);
· 1С:Школьная библиотека, редакция 5.04 (7.70.504);
· 1С:Школьная Библиотека ПРОФ, редакция 5.06 (7.70.506);
2. Расширен функционал поиска в электронном каталоге:
· Добавлена опция "Простой поиск", которая реализует поиск по всем полям библиографической записи. Поиск является полнотекстовым, учитывающим морфологию слов, и позволяет вводить любой параметр, не указывая, к какому полю библиографической записи он относится.
· Изменена архитектура хранения данных: в момент сохранения библиографической записи в базу данных, библиографическое описание разбивается на отдельные слова, для хранения которых предназначен регистр сведений "Слова библиографических записей".
· Добавлена опция выбора вида сравнения в форме расширенного поиска для каждого поискового элемента. Вид сравнения по умолчанию и доступность изменения вида сравнения настраиваются в справочнике "Варианты настроек расширенного поиска".
3. Реализована возможность импорта экземпляров изданий из файла в формате ISO 2709 (Международный стандарт библиографического описания) при учете поступлений (документ "Поступление в фонд").
4. Расширены возможности формата RUSMARC для создания библиографической записи: для поля (подполя) 610a добавлена возможность указывать справочники подполей. Добавлен справочник подполя "Ключевые слова".
5. Разработан механизм проверки библиографических записей.
Расширен список проверок и добавлена возможность сохранения библиографических записей, несмотря на ошибки. Данная опция позволяет импортировать библиографические записи, не являющиеся эталонными, из других автоматизированных библиотечных систем, корпоративных электронных каталогов, сайтов отечественных и зарубежных библиотек.
6. Добавлены опции настроек использования электронного библиотечного фонда с учетом разграничения доступа различных групп читателей к различным изданиям в электронном формате - добавлены опция "Использовать группы доступа читателей" и справочник "Группы доступа читателей". Доступ можно предоставлять как ко всем файлам (документам в электронном формате), так и ограничивать выдачей только определенных электронных документов с учетом групп доступа для читателей.
7. Расширен спектр настроек пользователей (читателей и библиотекарей) для работы с электронным каталогом:
· Для читателей добавлена возможность устанавливать отбор найденных изданий по дате поступления экземпляров в фонд.
· При просмотре и редактировании библиографического описания документа реализована возможность установить "связанные" библиографические записи: добавлена опция "Использовать подполе 6", если требуется внутри библиографической записи связывать поля, и опция "Использовать подполе 7", если требуется добавлять поля с альтернативной графикой.
· Добавлена опция "Использовать полный редактор библиографической записи", которая позволяет скорректировать редактор для библиографирования по умолчанию ("полный" или "упрощенный"). Настройка "Использовать шаблон по умолчанию:" позволяет установить один шаблон для создания и редактирования библиографических записей.
8. Расширены возможности создания вариантов каталожной карточки для аналитических записей, которые можно настроить как для пользователя при просмотре библиографического описания в желаемом виде каталожной карточки, так и для каталогизатора при создании и редактирований библиографических описаний.
Есть конфигурация, которая облегчает работу разработчика, избавляя его от таких «тривиальных» работ – это «Библиотека стандартных подсистем» (БСП), которая включает в себя набор универсальных функциональных подсистем и фрагменты раздела «Администрирование», предназначенных для использования в прикладных решениях на платформе «1С:Предприятие». Библиотека не является законченным (с предметной точки зрения) прикладным решением, но при этом подсистемы библиотеки могут использоваться в конфигурации-потребителе как все вместе, так и по отдельности. И для этого в БСП входит специальный помощник внедрения, использование которого помогает существенно сэкономить время при разработке новой конфигурации.
Сам помощник выполнен в виде пошагового мастера, с помощью которого разработчик указывает нужные ему подсистемы, а мастер создаст заготовку, с которой можно работать в дальнейшем. По сути дела мы получаем заготовку для будущей конфигурации.
Запустим БСП (у нас редакция 2.3, версия 2.3.3.63), перейдем в раздел «Инструменты разработчика» U94; «Первое внедрение БСП»:
Здесь нам откроется «Помощник внедрения БСП». Сам помощник выглядит как пошаговый помощник, где на первом этапе мы выбираем подсистемы, которые будут нам нужны в разрабатываемой конфигурации. После этого нужно указать файл (в формате xml), в котором сохраним эти настройки.
После чего переходим ко второму этапу: указываем дополнительные параметры для каждой из выбранных подсистем.
После выбора всех параметров система проверит, все ли было корректно выбрано и предложит разные варианты отслеживания ошибок (Таблица внедрения подсистем или Отчет по внедрению БСП).
В статье кратко описана работа с «Помощником внедрения БСП», потому что этот инструмент не очень популярен. Чаще на практике разработчики действуют по такой схеме: на пустую конфигурацию устанавливают необходимые подсистемы БСП (здесь еще может помочь «Помощник внедрения БСП»), но обычно с БСП на новую пустую конфигурацию переносят все подсистемы.
Далее рассмотрим на примере, когда с БСП в «1С:Бухгалтерия предприятия» (БП) нужно перенести некую подсистему.
У нас есть две конфигурации: первая (основная) - со всеми подсистемами БСП, вторая (файла) - БП.
Далее порядок действий следующий:
1. Включить возможность редактирования основной конфигурации.
2. Вызвать меню Конфигурация - Сравнить, объединить с конфигурацией из файла.
3. Выбрать файл с расширением cf конфигурации БП.
4. На предложение постановки на поддержку ответить Да.
5. Далее в окне сравнения - снять все флажки (снять флажок с корневого элемента).
6. Выполнить Действия - Отметить по подсистемам.
7. Отметить подсистемы, которые отсутствуют в нашей основной конфигурации – взять из файла, но подсистемы, которых нет в конфигурации из файла, нужно оставить в основной конфигурации (по умолчания так и будет), далее нажать Установить.
8. Отметить к объединению свойства корневого элемента: Основные роли, Модуль управляемого приложения, Модуль сеанса, Модуль внешнего соединения, Модуль обычного приложения, Режим использования модальности, Режим использования синхронных вызовов расширений платформы и внешних компонент, Режим совместимости интерфейса, Режим совместимости. Нажать Выполнить.
9. В окне Настройка правил поддержки - Ок.
10. Обновить конфигурацию базы данных (F7).
11. Далее, скорее всего, появится следующая ошибка:
«… (объект входит в состав одноименного общего реквизита)» или «… : Использование определяемых типов в режиме совместимости Х.Х.Х. (к примеру, автор) и ниже недопустимо» ; «ОбщаяКартинка: Имя не уникально!»
12. Для объекта, который входит в состав одноименного общего реквизита – снять с поддержки, удалить объект и ссылки на него. Выполнить поиск ссылок на удаляемые объекты – удалить ссылки.
13. Поменяйте режим совместимости выше Х.Х.Х.
14. Обновить конфигурацию базы данных (F7). Далее, если возвращаетесь на пункт 11, выполнить пункти 12 и 13, потом 14.
В принципе это и все – «автоматическая» часть работы закончена. Начинается самый «интересный» этап работ: если Вы уже подумали, что конфигурация «взлетела», то, скорее всего, Вы сильно ошибаетесь.
Для начала проверяйте общие модули, включены ли подсистемы в командный интерфейс и прочее моменты. Когда все «как бы готово», приступайте к отладке.
Находите внедренную подсистему, и далее работаете так: если все хорошо, то Вас можно поздравить, если же нет – возвращаетесь в конфигуратор и удаляете код неиспользуемых подсистем либо добавляйте то, что нужно.
И так выполняете отладку до тех пор, пока не убедитесь в отсутствии ошибок.
В большинстве случаев никаких проблем с этой библиотекой не наблюдается - обновлятор сам автоматически регистрирует и использует библиотеку нужной версии 1с, но изредка возникают случаи (в основном на серверных ОС), когда требуются "пляски с бубном".
Как понять, что у нас проблемы с COM
Для этого нажимаем кнопку "Проверить настройки" удерживая клавишу "Shift" на клавиатуре:
При нормальной работе COM отчёт будет примерно таким:
При проблемах же с COM возникнет вот такая или похожая ошибка:
Ещё может писать, что -то типа " Не удалось создать программное подключение к 1С ".
Да, судя по тесту, у нас проблемы с COM
Прежде всего, о какой именно библиотеке идёт речь? Эта библиотека comcntr.dll, которая находится в папке bin конкретной платформы 1с:
Эта библиотека устанавливается и автоматически регистрируется в системе при установке платформы.
Кроме того, обновлятор перед тем как подключаться к базе через внешнее соединение сам дополнительно регистрирует в системе библиотеку из нужной версии платформы при помощи команды:
Итак, что мы можем предпринять?
Шаг №0
Обратите внимание на утилиту для отображения и регистрации библиотек RegDllView. При помощи неё вы как минимум сможете контролировать результат работы следующих шагов.
Шаг №1
Прежде всего убеждаемся, что у нас действительно проф-версия платформы, потому что для базовой версии платформы внешнее подключение к базам работать и не должно (это ограничение платформы).
Чтобы понять какая у нас платформа (базовая или проф) выполним вот этот пункт.
Если лицензия на платформу у нас всё же не проф, а базовая, то все остальные шаги не имеют смысла. Внешнее подключение к базам у нас работать не будет (из-за ограничений платформы). Ничего не остаётся, кроме как настроить базы вот так.
Шаг №2
Далее пробуем запустить обновлятор с правами администратора.
Если у вас включён UAC, то добиться этого можно, нажав на ярлыке обновлятора правой кнопкой, и выбрав вариант "Запуск от имени администратора".
Далее выбираем базу и нажимаем кнопку "Проверить настройки". Если ошибка пропала и больше не воспроизводится даже при обычном запуске обновлятора (без прав администратора) - поздравляю, проблема решена. Если нет - идём дальше.
Шаг №3
В 32-битной версии ОС пробуем выполнить команду
В 64-битной версии ОС команда будет такой:
- для регистрации 64-битной платформы 1С:
- для регистрации 32-битной платформы 1С:
Эти команды запускаем от имени пользователя с правами администратора. А при включённом UAC, запускаем cmd через "Запуск от имени администратора", либо через такой же запуск написанного батника.
Если команда регистрации не помогла, то нужно предварительно удалить регистрацию библиотеки comcntr.dll, запустив ту же команду вызова regsvr32 с ключом /u
Если этот шаг не помог - идём дальше.
Шаг №4
Похоже, что у обновлятора не получается зарегистрировать COM компоненту из-за настроек безопасности на вашем сервере.
В этом случае:
- Заходим в Панель управления - Администрирование - Службы компонентов.
- Переходим к ветке Компьютеры - Мой компьютер - Приложения COM+.
- В контекстном меню выбираем Создать - Приложение. Откроется Мастер установки приложений COM+.
- Нажимаем "Далее".
- Выбираем "Создать новое приложение".
- Вводим имя "V83COMConnector". Устанавливаем переключатель "Серверное приложение". Нажимаем "Далее".
- На следующем шаге устанавливаем "Текущий пользователь". Нажимаем "Далее".
- Нажимаем "Готово".
- В появившейся ветке V83COMConnector переходим к подветке Компоненты.
- В контекстном меню выбираем Создать - Компонент. Откроется Мастер установки компонентов COM+.
- Нажимаем "Далее".
- Выбираем "Установка новых компонентов".
- Выбираем файл <каталог 1С>\bin\comcntr.dll.
- Нажимаем "Далее" - "Готово".
- Переходим к ветке V83COMConnector.
- В контекстном меню выбираем "Свойства". В открывшемся окне переходим на вкладку «Безопасность».
- Снимаем галку «Принудительная проверка доступа для приложений». Ставим галку "Применить политику программных ограничений". Устанавливаем Уровень ограничений - "Неограниченный".
- Нажимаем "ОК".
После этого обновлятор должен смочь самостоятельно регистрировать компоненты всех версий платформ, а не только той, которую мы прописали в компоненте.
Шаг №5
Бывает так, что помогает только повторная переустановка платформы (при этом происходит корректная регистрация компоненты).
Шаг №6
Если проблема начала возникать сразу после обновления платформы 1с, то вероятнее всего новой версии платформы 1с не хватает какого-нибудь сервиспака или обновления для вашей операционной системы. Поэтому если есть возможность - ставим их все, если нет - действуем выборочно согласно этой ссылке.
Шаг №7
Бывает так, что всё работает при обычном запуске обновлятора, но не работает при запуске с повышением привилегий до администратора, когда вы запускаете обновлятор через пункт меню "Запустить от имени администратора" или из программы (типа TotalCommander), которая сама запущена с повышенными привилегиями.
С уважением, Владимир Милькин (преподаватель школы 1С программистов и разработчик обновлятора).
Как помочь сайту: расскажите (кнопки поделиться ниже) о нём своим друзьям и коллегам. Сделайте это один раз и вы внесете существенный вклад в развитие сайта. На сайте нет рекламы, но чем больше людей им пользуются, тем больше сил у меня для его поддержки.
Читайте также: