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

20.07.17

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

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

Скачать файлы

Наименование Файл Версия Размер
НеактивностьВебКлиента
.epf 7,89Kb
40
.epf 7,89Kb 40 Скачать

По мотивам дискуссии на партнерском форуме 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С УТ 11, КА 2, ERP2, Розница 2/3, УНФ 16/3, БП 3, ЗУП 3 и подобных (УФ, Платформа 8.3.14+)

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

12000 руб.

06.12.2023    2987    15    1    

34

SALE! 20%

Infostart УДиФ: Управление данными и формами

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

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

10000 8000 руб.

10.11.2023    3560    11    1    

34

SALE! 30%

PowerTools

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

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

3600 2520 руб.

14.01.2013    177767    1074    0    

849

Ускоренное проведение документов (x4), устранение ошибок 60/62 счетов и зачет авансов (Бухгалтерия 3.0)

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

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

14400 руб.

29.04.2020    27387    79    146    

59

Система хранения присоединенных файлов в томах на диске

Инструменты администратора БД Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Управление производственным предприятием Платные (руб)

Конфигурация Комплексная автоматизация 1.1 (и УПП 1.3 тоже) хранит файлы и изображения в справочнике Хранилище дополнительной информации в реквизите Хранилище типа ХранилищеЗначений. Та же история с ВложениямиЭлектроннойПочты. Но при этом присоединенные файлы в Электронном документообороте хранит в томах на диске. Эта доработка позволяет использовать стандартный механизм хранения файлов, изображений и вложений электронных писем в томах на диске. При этом можно разделить тома хранения по объектам конфигурации.

4200 руб.

10.11.2015    61320    88    59    

73

"Менеджер потоков 2.1": УПП: "Восстановление партий"

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

Как оптимизировать то, что, считалось, не поддается оптимизации? Как повысить доступность базы данных? Как проводить самую «времяемкую» операцию не по паре раз в неделю, а по несколько раз в день*? Ответ есть!

20000 руб.

12.09.2019    11748    5    9    

7

Брандмауэр для сервера 1С Предприятие 8 - внешнее управление сеансами

Инструменты администратора БД Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

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

3600 руб.

06.02.2017    31113    31    18    

47

Хранилище файлов на SQL

Инструменты администратора БД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Управленческий учет Платные (руб)

Привязка файлов / сканов к объектам 1С с сохранением их на SQL-сервере

12000 руб.

09.10.2019    10987    5    8    

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

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

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

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

Обычные формы в веб-клиенте не доступны, соответственно, данный метод к ним неприменим. Замечу, что и при управляемых формах метод работает только в веб-клиенте, но не в тонком/толстом.
5. Glebis 13 21.07.17 14:14 Сейчас в теме
Передо мной стоит задача: отключать сессии неактивных пользователей. Ваша статья натолкнула меня на мысль - определять период "не активности" по времени без движения мыши.
Вопрос: можно ли добавив на обычную или управляемую форму (не веб интерфейс) рабочего стола элемент "ПолеHTMLДокумента" событием onmousemove сбрасывать таймер обработчика ожидания, который закрывает текущую сессию?
6. VitaliyCeban 461 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 1777 01.12.17 09:21 Сейчас в теме
8. VitaliyCeban 461 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 461 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 118 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Документа при нажатии
&НаКлиенте
Процедура ФИ_СкриптАвтозакрытияПриНажатииВместо(Элемент, ДанныеСобытия, СтандартнаяОбработка)
	
	ЗавершитьРаботуСистемы(Ложь);
	
КонецПроцедуры
14. CyclesOfID 118 27.05.20 16:13 Сейчас в теме
Сработало, только top.document поменял просто на document, ибо не на всех сайтах у 1с есть доступ к самому сайту
Плюс автору
17. kild 89 19.11.21 04:20 Сейчас в теме
@VitaliyCeban
Если показывается окно авторизации, но вход еще не выполнен, то при закрытие браузера или переходе в "about:blank" сеанс с пользователем без имени так и останется висеть в активных пользователях.

Есть какое-нибудь решение?
18. bva630 4 11.07.22 11:48 Сейчас в теме
19. asamorod 55 22.09.23 09:43 Сейчас в теме
Оставьте свое сообщение