Торговое оборудование. Доработка функции ПолучитьИмяКомпьютераТО() в типовых конфигурациях 1С 8.2

28.08.15

Разработка - Универсальные функции

Много раз замечал, что в типовых решениях не доработана функция определения имени клиентского компьютера, особенно когда работа с торговым оборудованием идет через RDP. В публикации представлен метод, решающий эту проблему. Представленная функция взята из типовой конфигурации "1С: Комплексная автоматизация, ред 1.1"

На уникальность статьи не претендую, но, возможно, представленный метод кому-нибудь поможет.

Мною было замечено, что при работе с типовыми конфигурациями типа УТ 10.3 и Розница для платформы 8.2 возникают проблемы с торговым оборудованием при работе через RDP. В конфигурации КА 1.1 данная проблема решена, возможно, ее нет и в УПП.

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

Вся суть кроется в функции ПолучитьИмяКомпьютераТО() в модуле обработки СерверТО. В типовых УТ 10.3 и Розница она выглядит так:

Функция ПолучитьИмяКомпьютераТО() Экспорт

	Если мИмяКомпьютера = Неопределено Тогда
		мИмяКомпьютера = ВРег(ИмяКомпьютера());
	КонецЕсли;

	Возврат мИмяКомпьютера;

КонецФункции // ПолучитьИмяКомпьютераТО()

Данную функцию нужно заменить на следующую:

Функция ПолучитьИмяКомпьютераТО() Экспорт

	Если мИмяКомпьютера = Неопределено Тогда
	    WSS = Новый COMОбъект("WScript.Shell");
	    WSSE = WSS.Environment("Process");

	    мИмяКомпьютера = ВРег(WSSE.Item("ClientName"));
	
		Если ПустаяСтрока(мИмяКомпьютера) Тогда
			мИмяКомпьютера = Неопределено;
		КонецЕсли;
	КонецЕсли;	
	
	Если мИмяКомпьютера = Неопределено ИЛИ ВРег(СокрЛП(мИмяКомпьютера)) = "CONSOLE" Тогда
		мИмяКомпьютера = ВРег(ИмяКомпьютера());
	КонецЕсли;

	Возврат мИмяКомпьютера;

КонецФункции // ПолучитьИмяКомпьютераТО()

Вот и все. Всем удачи и спасибо за внимание!

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

См. также

Загрузка и выгрузка в Excel Универсальные функции Программист 1С:Предприятие 8 Россия Бесплатно (free)

Описанный ниже подход позволяет в три шага заполнять формулы в Excel файлы, вне зависимости от ОС сервера (MS Windows Server или Linux). Подход подразумевает отказ от работы с COM-объектом в пользу работы через "объектную модель документа" (DOM).

30.10.2025    3397    Abysswalker    8    

45

Универсальные функции Работа с интерфейсом Программист 1С:Предприятие 8 Бесплатно (free)

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

14.05.2025    6320    DeerCven    15    

57

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

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

21.05.2024    48646    dimanich70    83    

169

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Абонемент ($m)

Задача: вставить картинку из буфера обмена на форму средствами платформы 1С.

1 стартмани

18.03.2024    7288    6    John_d    13    

59

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

Пришлось помучиться с GUID-ами немного, решил поделиться опытом, мало ли кому пригодится.

12.02.2024    60820    atdonya    31    

69

Универсальные функции Программист 1С:Предприятие 8 Бесплатно (free)

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

30.11.2023    9078    ke.92@mail.ru    17    

68
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. deadman66 28.08.15 13:54 Сейчас в теме
Да, метод рабочий. Использую уже года два такое решение. Вот только не проверял при админском запрете выполнения скриптов на RDP (в исключение вывалиться или нет).
2. Вурдалак 27 28.08.15 18:45 Сейчас в теме
(1) deadman66, ну этот метод типовой. вроде пока работает, правда у нас запрета вроде не стоит. надо у Админа уточнить
3. buddha667 02.09.15 10:24 Сейчас в теме
Я функцию модифицировал минимально:

Функция ПолучитьИмяКомпьютераТО() Экспорт

    Если мИмяКомпьютера = Неопределено Тогда
        //мИмяКомпьютера = ВРег(ИмяКомпьютера());
        мИмяКомпьютера = ВРег(ИмяКомпьютераПолное());
    КонецЕсли;

    Возврат мИмяКомпьютера;

КонецФункции // ПолучитьИмяКомпьютераТО()
Показать


А сам алгоритм вынес отдельно в глобальный модуль, ибо помнится, где-то еще пришлось заменить ИмяКомпьютера()

Функция ИмяКомпьютераПолное() Экспорт
	
	ИмяКомпьютера = "";
	Попытка
		WshShell = Новый COMОбъект("WScript.Shell");
		WshSysEnv = WshShell.Environment("Process");
		ИмяКомпьютера = WshSysEnv.Item("CLIENTNAME");
	Исключение
	КонецПопытки;
	
	Если НЕ ЗначениеЗаполнено(ИмяКомпьютера) ИЛИ ВРег(СокрЛП(ИмяКомпьютера)) = "CONSOLE" Тогда
		ИмяКомпьютера = ИмяКомпьютера();
	КонецЕсли;
	
	Возврат ИмяКомпьютера;
	
КонецФункции
Показать


ЗЫ: Воспользовался вашим советом, добавил ...
ИЛИ ВРег(СокрЛП(ИмяКомпьютера)) = "CONSOLE"
...
4. M_Volkov 5 12.10.17 17:27 Сейчас в теме
То что можно определить подключившийся компьютер к терминальному серверу это здорово. Но он же может незаметно отвалиться. Как в нужный момент определить, что он на месте, все еще подключен, и можно воспользоваться его оборудованием? Например, отбить чек на фискальном регистраторе.
5. M_Volkov 5 14.10.17 06:55 Сейчас в теме
Проверить подключение компьютера можно командой: ping. А какой командой проверить порт Com20 самой кассы?
6. acanta 08.10.18 12:13 Сейчас в теме
Для отправки сообщения требуется регистрация/авторизация