Получение UNC пути в 1С

15.02.10

База данных - Инструменты администратора БД

Иногда возникает ситуация когда надо знать UNC путь к какому либо файлу

Итак, я столкнулся с ситуацией когда необходимо знать UNC путь к базе данных.

 

Universal Naming Convention — универсальное соглашение об именовании

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

Синтаксис для Universal Naming Convention (UNC), как путь к сетевому ресурсу, представляется следующим:

\\server_name\share_name[\path]

где «share_name» — это сетевое имя общей папки, а «path» — путь к файлу из общей папки (необязательный параметр).

UNC путь «\\Srv1\Folder1\Sub1\report.doc» показывает, что документ report.doc расположен в подпапке — Sub1, общей сетевой папки по имени — Folder1, на файловом сервере по имени — Srv1.

В общем не нашел как это возможно получить средствами 1С. Пришлось извратиться, да не сильно..

Вам понадобиться: 

1. Dynwrapx.dll Можно взять с сайта http://www.scriptcoding.info/dynwrapx.html#addons.

2. Регистрация в как OLE  в системе Dynwrapx.dl

команда: regsvr32 \\ПутьКФайлу\Dynwrapx.dll

3. Регистрация методов 

 

DX = новый COMОбъект("DynamicWrapperX");

 //Регистрация нужной процедуры из библиотеки Mpr.dll

DX.Register(" Mpr.dll", " WNetGetUniversalName", "i=pupu", "r=l");

 

  Промежуток  = Путь;

 

    // Объявляем буфер 

    ppBuffer = DX.StrPtr(DX.Space(260));

    // Передаю пустую строку с 1 символом 

    ppBufferSize = DX.StrPtr(DX.Space(1));

 

    // Получаем UNC путь

    // DWORD WNetGetUniversalName(

    //  __in     LPCTSTR lpLocalPath, //Передаем строку как есть

    //  __in     DWORD dwInfoLevel,   //1 - UNIVERSAL_NAME_INFO_LEVEL  2 - REMOTE_NAME_INFO_LEVEL

    //  __out    LPVOID lpBuffer,     //Передаем адресс буфера для заполнения строкой

    //  __inout  LPDWORD lpBufferSize //Передаем адресс буфера для помещения туда полученного размера 

    //);

    // более подробно на сайте microsoft: http://msdn.microsoft.com/en-us/library/aa385474(VS.85).aspx

    ppReturn_Erorr = DX.WNetGetUniversalName(Промежуток,1,ppBuffer,ppBufferSize);

 

    ////////////////////

    // ОПИСАНИЕ ОШИБОК 

    ERROR_BAD_DEVICE            = 1200;

    //The string pointed to by the lpLocalPath parameter is invalid.

    ERROR_CONNECTION_UNAVAIL    = 1201;

    //There is no current connection to the remote device, but there is a remembered (persistent) connection to it.

    ERROR_EXTENDED_ERROR        = 1208;

    //A network-specific error occurred. Use the WNetGetLastError function to obtain a description of the error.

    ERROR_MORE_DATA             = 234;

    //The buffer pointed to by the lpBuffer parameter is too small. The function sets the variable pointed to by the lpBufferSize parameter to the required buffer size. More entries are available with subsequent calls.

    ERROR_NOT_SUPPORTED         = 50;

    //The dwInfoLevel parameter is set to UNIVERSAL_NAME_INFO_LEVEL, but the network provider does not support UNC names. (None of the network providers support this function.)

    ERROR_NO_NET_OR_BAD_PATH    = 1203;

    //None of the network providers recognize the local name as having a connection. However, the network is not available for at least one provider to whom the connection may belong.

    ERROR_NO_NETWORK            = 1222;

    //The network is unavailable.

    ERROR_NOT_CONNECTED         = 2250;

    //The device specified by the lpLocalPath parameter is not redirected.

 

    Если ppReturn_Erorr = 0 Тогда

 

        // Получение значения результата из буфера

        Результат = СокрЛП(DX.StrGet(ppBuffer)) ;

 

        Если Не ПустаяСтрока(СокрЛП(Результат))

            И СокрЛП(Результат) <> СокрЛП(Путь) Тогда 

            // Для символа первые не определяются отрежим их

            Путь = Прав(Результат,СтрДлина(Результат)-2);

        КонецЕсли;

        // Необходимо очистить ppBuffer,pBytesReturned

        ppBuffer = Неопределено;

        ppBufferSize = Неопределено;

 

    ИначеЕсли ppReturn_Erorr = ERROR_NOT_CONNECTED Тогда

        Ошибка = "The device specified by the lpLocalPath parameter is not redirected.";

        Сообщить("Ошибка преобразования к UNC: " + Ошибка);     

    ИначеЕсли ppReturn_Erorr = ERROR_NO_NETWORK Тогда

        Ошибка = "The network is unavailable.";

        Сообщить("Ошибка преобразования к UNC: " + Ошибка);     

    ИначеЕсли ppReturn_Erorr = ERROR_NO_NET_OR_BAD_PATH Тогда

        Ошибка = "None of the network providers recognize the local name as having a connection. 

        |However, the network is not available for at least one provider to whom the connection may belong.";

        Сообщить("Ошибка преобразования к UNC: " + Ошибка);     

     ИначеЕсли ppReturn_Erorr = ERROR_NOT_SUPPORTED Тогда

        Ошибка = "The dwInfoLevel parameter is set to UNIVERSAL_NAME_INFO_LEVEL, but the network provider does not support UNC names. 

        |(None of the network providers support this function.)";

        Сообщить("Ошибка преобразования к UNC: " + Ошибка);     

    ИначеЕсли ppReturn_Erorr = ERROR_MORE_DATA Тогда

        Ошибка = "The buffer pointed to by the lpBuffer parameter is too small. The function sets the variable pointed to by the lpBufferSize parameter to the required buffer size. 

        |More entries are available with subsequent calls.";

        Сообщить("Ошибка преобразования к UNC: " + Ошибка);     

    ИначеЕсли ppReturn_Erorr = ERROR_EXTENDED_ERROR Тогда

        Ошибка = "A network-specific error occurred. Use the WNetGetLastError function to obtain a description of the error.";

        Сообщить("Ошибка преобразования к UNC: " + Ошибка);     

    ИначеЕсли ppReturn_Erorr = ERROR_CONNECTION_UNAVAIL Тогда

        Ошибка = "There is no current connection to the remote device, but there is a remembered (persistent) connection to it.";

        Сообщить("Ошибка преобразования к UNC: " + Ошибка);     

    ИначеЕсли ppReturn_Erorr = ERROR_BAD_DEVICE Тогда

        Ошибка = "The string pointed to by the lpLocalPath parameter is invalid.";

        Сообщить("Ошибка преобразования к UNC: " + Ошибка);     

    Иначе

        Сообщить("Неизвестная ошибка преобразования к UNC"); 

    КонецЕсли;

 

 

 

Данным кодом можно получить F:\... -> \\Server\...

Меня данная фигня спасла .. Если кто знает как получать UNC путь средствами 1С буду благодарен если напишет как это сделать.

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

См. также

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта 1С:Предприятие 8 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP, УНФ, КА и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку одновременно в несколько потоков. А так же автоматически, без непосредственного участия пользователя. Решение в Реестре отечественного ПО

24900 руб.

20.08.2024    64851    341    168    

301

Инструменты администратора БД Инструментарий разработчика Роли и права Программист 1С:Предприятие 8 1C:Бухгалтерия Россия Платные (руб)

Расширение позволяет без изменения кода конфигурации выполнять проверки при вводе данных, скрывать от пользователя недоступные ему данные, выполнять код в обработчиках. Не изменяет данные конфигурации, легко устанавливается практически на любую конфигурацию на управляемых формах.

17000 руб.

10.11.2023    24600    92    42    

101

Инструменты администратора БД Роли и права Системный администратор Программист Пользователь 1С 8.3 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Документооборот 1С:Зарплата и кадры государственного учреждения 3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Роли… Вы тратите много времени и сил на подбор ролей среди около 2400 в ERP или 1500 в Рознице 2, пытаясь понять какими правами они обладают? Вы все время смотрите права в конфигураторе или отчетах чтоб создать нормальные профили доступа? Вы хотите наглядно видеть какие права дает профиль и редактировать все в простом виде? А может хотите просто указать подсистему и дать права на просмотр и добавление на объекты и не лезть в дебри прав и чтоб обработка сама подобрала нужные роли? Все это теперь стало возможно! Обновление от 10.04.2026, версия 1.4.0, работает в 1С:ФРЕШ!

24400 руб.

06.12.2023    22054    80    10    

113

Закрытие периода Инструменты администратора БД Корректировка данных Бухгалтер Пользователь 1С:Предприятие 8 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Расширение «Оперативное проведение» в 4 раза уменьшает время проведения документов и закрытия месяца. Является комплексным решением проблем 62 и 60 счетов. Оптимизирует проведение при включенной функциональной опции «Раздельный учет НДС». Используется в более 10 организациях уже 2 года. Совместимо с конфигурацией Бухгалтерия 3.0 (+КОРП).

14640 руб.

29.04.2020    49471    134    159    

90

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

Данная обработка позволит Вам легко и просто, а главное - быстро, выполнить сравнение данных между ЛЮБЫМИ базами (и РИБ, по правилам конвертаций) по контрольным суммам выбранных объектов баз 1С, работающих на платформах 8.3 и выше. Удобный и понятный интерфейс в виде "мастера". Высокая скорость сравнения достигается за счет специального алгоритма расчета контрольной суммы объекта/записи и сравнения по данным суммам объектов 2х баз через файл. Имеется возможность выбора реквизитов, по которым система будет сравнивать объекты. Сравнение количества записей в движениях документов, возможность сравнивать данные по правилам конвертации и не только! Выбор объектов конфигурации для КАЖДОГО узла в отдельности с индивидуальным отбором для каждого объекта конфигурации, работа с FTP, сохранение или загрузка настроек, сохранение или загрузка результата сравнения, регистрация на обмен объекта и его движений. (Обновление от 12.11.2024, версия 2.2-2.5)

24400 руб.

27.10.2017    45362    31    13    

49

Чистка данных Инструменты администратора БД Администрирование 1С 8.3 1С:Документооборот 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Управление холдингом 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Платные (руб)

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

23999 руб.

20.02.2026    870    1    0    

4
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. SiAl 76 16.02.10 14:02 Сейчас в теме
А поиграться с выводом net share или использовать WMI не гуд? Думаю кода было бы меньше.
2. khorevaa 114 17.02.10 11:08 Сейчас в теме
(1) Да кода не так уж и много в основном код отладки ошибок ..
Да и чет не в курсе как получить UNС через net share или WMI.
Главное что бы путь возвращался в 1С )
3. Kurt 110 17.02.10 12:28 Сейчас в теме
Не понял. Зачем так сложно? ... или не понял :)
В 1С 7.7 есть следующие полезные вещи:

КаталогИБ() - Возвращает имя каталога базы данных (изначально вроде об этом шла речь?). Если база запущена по сетевому пути, то UNC путь вам и вернет. (Если база запущена с подключенного сетевого диска, то извините, этот диск вам и покажет)

РасположениеФайла(<Путь>,<Имя>) - Данный метод следует использовать только в модуле формы внешнего отчета. Если отчет запущен из сети, то UNC путь вам и вернет в переменной Путь, а в переменную Имя - соответственно имя работающего отчета.

ну вот как-то так.
4. khorevaa 114 03.03.10 08:36 Сейчас в теме
(3) К сожалению вы говорите о 7.? мне же данное действо надо сделать в 8.1. В 8.1 отсутствует "РасположениеФайла", а КаталогИБ не подходит т.к. необходимо получить не путь к базе которая запущена, а UNC путь к внешней базе данных на ADS. Вот поэтому и был я вынужден "извращатся" :D
5. pavlo 30.06.10 14:17 Сейчас в теме
а если юзаешь обработку файлов через ФС.НайтиСледующийФайл() и т.д. в 7.7. никакое расположениеФайла() и КаталогИБ() не поможет :( идея не плохая, но мне имхо кажется как то муторно :) но своих пока идей нет, думаю.... ;)
6. AVKitov 19.11.20 12:54 Сейчас в теме
я возможно не понял смысла вышеописанных действий, но UNC путь, это просто путь к папке по сети. то-есть мы, создаем папку, расшариваем и видим путь к файлу.
Прикрепленные файлы:
7. andrey5000 10.07.25 20:19 Сейчас в теме
Все проще. Нажимаем ПКМ на нашу папку ( каталог), идем в "свойства". там выбираем вкладку "Доступ". кнопка "Дать доступ" - выбираем пользователя при желании, которому давать доступ и "Ок" . В результате будет дана ссылка в формате UNC к папке.
Прикрепленные файлы:
8. ankr 19 31.10.25 11:52 Сейчас в теме
Возникла у меня такая необходимость, выгрузить прикрепленные файлы
во внешний каталог.
Как верно было написано выше, получить необходимый для этого UNC-путь
проще всего - расшарив соответствующую папку.
Сетевой путь до нее и будет путь в формате UNC, например:
\\MyServer\1CFiles2
Но проблема в том, что мне совсем не хотелось открывать сервер и делать
к нему какой-то сетевой доступ (даже для ограниченного пользователя).
Я задался вопросом: можно ли получить UNC-путь без этого?
И такую возможность я нашел!
Спасибо статье:
https://habr.com/ru/articles/731628/

Например, есть путь к локальной папке:
E:\1CFiles2
Без расшаривания, UNC-путь можно написать так:
\\127.0.0.1\e$\1CFiles2
или
\\localhost\e$\1CFiles2

И да, в 1С это сработало.
Для отправки сообщения требуется регистрация/авторизация