Автоматическое отключение неактивных веб-клиентов

20.07.17

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

У вас организован доступ в базу через веб-клиент для посторонних лиц (веб-портал, веб-витрина, и т.д.), и вы испытываете проблему нехватки лицензий 1С из-за того, что пользователи оставляют открытыми вкладки с 1С, не работая в них? Есть решение!

Файлы

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

Наименование Скачано Купить файл
НеактивностьВебКлиента
.epf 7,89Kb
45 1 850 руб. Купить

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

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

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

По мотивам дискуссии на партнерском форуме https://partners.v8.1c.ru/forum/topic/1620757
Публикация сделана для тех, у кого нет доступа на партнерский форум.

Внешние пользователи, после того как поработают в 1С, любят не закрывать вкладку, а просто переключаются на другие. 

Попытка решить проблему типовыми средствами, кажущимися подходящими для данной ситуации:

1. В параметрах информационной базы установить следующие значения:
Время засыпания пассивного сеанса - 600 сек.
Время завершения спящего сеанса  - 10 сек.

2. При публикации базы на веб сервере указать параметр "Время жизни соединения в сек." - 600

Данные методы НЕ работают, по причите того что даже в пассивном режиме (неактивная вкладка браузера), в 1С выполняются множество обработчиков ожидания, в которых есть серверные вызовы (то же обновление динамического списка раз в минуту), поэтому метка неактивности клиента (используемая в механизме "Время засыпания пассивного сеанса") с каждым запросом отодвигается.

К сожалению, 1С не предоставляет штатных средств для определения времени последней активности пользователя.

 

Но есть работающий метод:

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

На "рабочем столе" 1С должна находиться как минимум одна форма. В эту форму нужно добавить Поле HTML документа. Для него можно установить минимальный размер, а цвет фона сделать равным цвету фона формы, чтобы его не было видно. Важное уточнение: поле должно иметь свойство Видимость = Истина, иначе оно попросту не будет создано на клиенте. 

Если на вашей форме нет даже самого малого свободного места, то можно создать две страницы (видимость переключателя = Ложь). На первую страницу переносятся все элементы формы, а на вторую Поле HTML документа. Затем при открытии формы нужно программно установить активной вторую страницу, а через 0.1 сек обратно первую. Если этого не сделать, то поле HTML физически создастся только после первой активации второй страницы, то есть, никогда (учитывая что переключатель невидим).

Затем в поле HTML загружаем javascript, который и будет выполнять всю работу. Доступ к родительскому окну осуществляется посредством идентификатора top.

<HTML>
<BODY>
    <SCRIPT>
        // Время завершения сеанса от последней активности пользователя, в миллисекундах.
        // Для 10-минутного тайм-аута следует установить 600000.
        var timeoutInMiliseconds = 5000; // 5 секунд.

        var onUserInactive = function() {
            // При наступлении тайм-аута переходим на пустую страницу, тем самым завершая сеанс 1С.
            top.location.href = 'about:blank';
        }

        // Первоначальный запуск обработчика ожидания.
        var wait = setTimeout(onUserInactive, timeoutInMiliseconds);

        var onUserActivity = function() {
            // При каждой активности пользователя перезапускаем обработчик ожидания.
            clearTimeout(wait);
            wait = setTimeout(onUserInactive, timeoutInMiliseconds);
        };

        // Подключаем обработчики отслеживания активности пользователя.
        top.document.onmousemove     = onUserActivity;
        top.document.onmouseover     = onUserActivity;
        top.document.mousedown         = onUserActivity;
        top.document.mouseup         = onUserActivity;
        top.document.onkeydown         = onUserActivity;
        top.document.onkeyup         = onUserActivity;
        top.document.focus             = onUserActivity;
        
        // Для этих панелей подключаемся отдельно именно к этим элементам, 
        // так как в обработчике установленном фирмой 1С установлен запрет на event propagation,
        // и top.document.onmousemove его не словит.
        top.document.getElementById('navigatorPanelArea').onmousemove = onUserActivity;
        top.document.getElementById('actionPanelArea').onmousemove = onUserActivity;

        // Ловим события движения мыши из вложенных фреймов (других полей html документа).  
        function bubbleIframeMouseMove(iframe) {
            try
            {
                // Save any previous handler
                var existingOnMouseMove = iframe.contentWindow.onmousemove;

                // Attach a new listener
                iframe.contentWindow.onmousemove = function(e) {
                    // Fire any existing listener 
                    if (existingOnMouseMove) existingOnMouseMove(e);

                    // Create a new event for the this window
                    var evt = document.createEvent("MouseEvents");

                    // We'll need this to offset the mouse move appropriately
                    var boundingClientRect = iframe.getBoundingClientRect();

                    // Initialize the event, copying exiting event values
                    // for the most part
                    evt.initMouseEvent(
                        "mousemove",
                        true, // bubbles
                        false, // not cancelable 
                        window,
                        e.detail,
                        e.screenX,
                        e.screenY,
                        e.clientX + boundingClientRect.left,
                        e.clientY + boundingClientRect.top,
                        e.ctrlKey,
                        e.altKey,
                        e.shiftKey,
                        e.metaKey,
                        e.button,
                        null // no related element
                    );

                    // Dispatch the mousemove event on the iframe element
                    iframe.dispatchEvent(evt);
                };
            }
            catch(err)
            {
            }
        }

        var iframes = top.document.getElementsByTagName('iframe');
        for (var i in iframes)
            bubbleIframeMouseMove(iframes[i]);
    </SCRIPT>
</BODY>
</HTML>


По истечении отведенного времени, сеанс веб-клиента завершится (останется пустая вкладка браузера).
Впрочем, если есть открытые формы с признаком Модифицированность = Истина (звездочка в конце заголовка формы), то сеанс не завершается автоматически, а происходит автоматическая активация вкладки 1С и отображение вопроса "Покинуть эту страницу?". Это типовое поведение, сделанное чтобы не потерять введенные данные, присутствующее и в тонком клиенте при закрытии приложения ("Данные были изменены. Сохранить изменения?").

Полная реализация метода в прикрепленной обработке.

Рекомендую ознакомиться с другой моей публикацией
Javascript и 1С. Кросс-платформенное взаимодействие //infostart.ru/public/398366/

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

См. также

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

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

14400 руб.

20.08.2024    42310    231    117    

216

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

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

16000 руб.

10.11.2023    19294    76    39    

92

Инструменты администратора БД Роли и права Системный администратор Программист Пользователь 8.3.14 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, пытаясь понять какими правами они обладают? Вы все время смотрите права в конфигураторе или отчетах чтоб создать нормальные профили доступа? Вы хотите наглядно видеть какие права дает профиль и редактировать все в простом виде? А может хотите просто указать подсистему и дать права на просмотр и добавление на объекты и не лезть в дебри прав и чтоб обработка сама подобрала нужные роли? Все это теперь стало возможно! Обновление от 17.06.2025, версия 1.3

19200 руб.

06.12.2023    17420    66    10    

99

Инструменты администратора БД Системный администратор Программист 1С v8.3 1C:Бухгалтерия Платные (руб)

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

3600 руб.

06.02.2017    33788    146    18    

51

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

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

14400 руб.

29.04.2020    39376    116    152    

82

Инструменты администратора БД Системный администратор Программист 1С v8.3 1C:Бухгалтерия Платные (руб)

Программный продукт предназначен для построения единой централизованной системы управления инфраструктурой и интеграционными процессами компании.

140000 руб.

10.08.2012    124805    9    122    

195

Администрирование Инструменты администратора БД Удаленное управление Системный администратор 1С v8.3 1С:Зарплата и Управление Персоналом 3.x Платные (руб)

Расширение разработано для автоматизации интеграции «1С:Зарплата и управление персоналом (редакция 3.1)» с сервисом Яндекс 360 через платформу «n8n». Расширение позволяет автоматически создавать учетные записи Яндекс для новых сотрудников, обновлять данные существующих сотрудников и блокировать учетные записи уволенных сотрудников. Обмен данными осуществляется через API Яндекс 360 с использованием промежуточного сервера платформы n8n, что обеспечивает гибкость, масштабируемость и упрощение интеграционных процессов.

5000 руб.

03.04.2025    1922    3    0    

4
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Leits 2 20.07.17 16:35 Сейчас в теме
я не до конца понял на какую форму нужно выводить HTML поле? там же их много(например Корзина, Рабочий стол, различные журналы заказы, РНК )
2. VitaliyCeban 468 20.07.17 16:56 Сейчас в теме
(1) На любую, которая остается открытой на всём протяжении работы. То есть на одну из форм из "рабочей области начальной страницы".
3. Glebis 13 21.07.17 12:56 Сейчас в теме
Статья очень нужная.

Не понял фразу, "Затем в поле HTML загружаем javascript,". У этого элемента куча событий, но никакой загрузки в свойствах элемента нет.

Подойдет этот способ для обычных форм?
4. VitaliyCeban 468 21.07.17 13:19 Сейчас в теме
(3) Код из публикации помещается в макет с типом ТекстовыйДокумент.
Затем в ПриСозданииНаСервере выполняете
ПолеHTML = ПолучитьОбщийМакет("МакетJavascript").ПолучитьТекст();

ПолеHTML это имя реквизита формы с типом "Строка", к которому привязано поле формы с видом "Поле HTML документа". Это вся загрузка.

Обычные формы в веб-клиенте не доступны, соответственно, данный метод к ним неприменим. Замечу, что и при управляемых формах метод работает только в веб-клиенте, но не в тонком/толстом.
VyacheslavShilov; +1 Ответить
5. Glebis 13 21.07.17 14:14 Сейчас в теме
Передо мной стоит задача: отключать сессии неактивных пользователей. Ваша статья натолкнула меня на мысль - определять период "не активности" по времени без движения мыши.
Вопрос: можно ли добавив на обычную или управляемую форму (не веб интерфейс) рабочего стола элемент "ПолеHTMLДокумента" событием onmousemove сбрасывать таймер обработчика ожидания, который закрывает текущую сессию?
6. VitaliyCeban 468 21.07.17 14:41 Сейчас в теме
(5) Нет, невозможно, так как в толстом/тонком клиенте omousemove будет отрабатывать движения мыши только внутри Поля HTML документа.

Вам должно помочь http://infostart.ru/public/20593/ или http://infostart.ru/public/16441/
16. NG21 12.11.21 11:17 Сейчас в теме
(5) Здравствуйте, как в итоге решили задачу?
7. ixijixi 2059 01.12.17 09:21 Сейчас в теме
8. VitaliyCeban 468 04.12.17 12:07 Сейчас в теме
(7) "Мы выживали как могли"...
9. kungfufox 24.10.18 10:27 Сейчас в теме
Сделал как написали.

Произошла ошибка:

На этой странице произошла ошибка сценария.
Не удалось задать свойство "onmousemove" ссылки,
значение которой не определено или не является нулл.
10. kungfufox 24.10.18 10:28 Сейчас в теме
править реестр не вариант.
Может надо как то править js код? под старый IE
или как решить?
11. VitaliyCeban 468 24.10.18 14:47 Сейчас в теме
(10) Попробуйте добавить в тег head следующее:
<met a http-equiv="X-UA-Compatible" content="IE=edge, 11, 9, 8" />

Удалите проблел между met a
Предполагается наличие минимум Internet Explorer 8.
12. BiTwaR 9 30.03.20 11:40 Сейчас в теме
В моем случае действие
top.location.href = 'about:blank';
страницу веб клиента делала пустой, но сеанс не завершался.
Платформа 8.3.16.1148 + Apache.
Сделал немного иначе. Вместо перехода на пустую страницу происходит нажатие на невидимую кнопку. Ну а далее:
&НаКлиенте
Процедура HTMLЗакрытиеПриНажатии(Элемент, ДанныеСобытия, СтандартнаяОбработка)
	ЗавершитьРаботуСистемы(Ложь);
КонецПроцедуры
Teplotrassamen; +1 Ответить
13. CyclesOfID 150 26.05.20 14:58 Сейчас в теме
(12) День добрый, Владимир!

А каким образом в java оформляется нажатие на кнопку формы 1с?
15. bilex 08.11.21 14:29 Сейчас в теме
(13) Добрый день!
Я реализовал так:
<BODY>
	<button type="button" id="fi_close" hidden>fi_close</button>
    <SC RIPT>

        var timeoutInMiliseconds = 300000; 

        var on UserInactive = function() {
            //top.location.href = 'about:blank';
           	document.getElementById('fi_close').click(); 
			return "success";    
        }
Показать

И добавил событие HTMLДокумента при нажатии
&НаКлиенте
Процедура ФИ_СкриптАвтозакрытияПриНажатииВместо(Элемент, ДанныеСобытия, СтандартнаяОбработка)
	
	ЗавершитьРаботуСистемы(Ложь);
	
КонецПроцедуры
VyacheslavShilov; +1 Ответить
14. CyclesOfID 150 27.05.20 16:13 Сейчас в теме
Сработало, только top.document поменял просто на document, ибо не на всех сайтах у 1с есть доступ к самому сайту
Плюс автору
17. kild 104 19.11.21 04:20 Сейчас в теме
@VitaliyCeban
Если показывается окно авторизации, но вход еще не выполнен, то при закрытие браузера или переходе в "about:blank" сеанс с пользователем без имени так и останется висеть в активных пользователях.

Есть какое-нибудь решение?
VyacheslavShilov; +1 Ответить
18. bva630 4 11.07.22 11:48 Сейчас в теме
19. asamorod 56 22.09.23 09:43 Сейчас в теме
Для отправки сообщения требуется регистрация/авторизация