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

20.07.17

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

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

Скачать файл

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

Наименование По подписке [?] Купить один файл
НеактивностьВебКлиента
.epf 7,89Kb
42
42 Скачать (1 SM) Купить за 1 850 руб.

По мотивам дискуссии на партнерском форуме 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 и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку сразу нескольких баз данных и выполнять их автоматически без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    14250    108    46    

108

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

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

15000 руб.

10.11.2023    11887    45    27    

67

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

18000 руб.

06.12.2023    10643    47    8    

78

SALE! %

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

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

4800 3840 руб.

14.01.2013    191152    1152    0    

920

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

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

14400 руб.

29.04.2020    33814    108    152    

75

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

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

3600 руб.

06.02.2017    32613    145    18    

51

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

Данная разработка позволит решить вопрос с резервным копированием Ваших баз в автоматическом режиме, расположенных на сервере 1С. Система умеет ставить блокировки на вход, блокировать фоновые задания, принудительно отключать сеансы пользователей. И все это система делает в автоматически при создании бэкапа (или через команду). Выгрузка происходит в родной формат 1С - .dt. Так же система умеет архивировать данные выгрузки с установкой пароля. Умеет менять расширение файла zip или dt на любое указанное вами, что позволит сохранить выгрузки от шифровальщика. Может удалять старые копии выгрузок, оставляя указанное количество резервных копий, начиная с самой поздней. Только для WINDOWS!

6000 руб.

06.11.2012    73733    629    45    

88

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

Многие сталкиваются с проблемой когда изображения, находящиеся в базе разные по объему и размерам. Менеджеры могут добавить файлы в очень высоком разрешении, объемом свыше 20 Мегабайт. База данных становится слишком большой, выгрузка на сайт идёт медленно и требуется много место на хостинге. Как сжать картинки и уменьшить размер базы 1С? Это можно сделать с помощью данной обработки. Существует возможность выбрать различные варианты для того чтобы уменьшить картинки: в разы, в процентах от первоначального объема, а также сделать картинки одинаковой ширины. В результате размер базы 1С значительно сократится (в зависимости от количества и размера картинок), а изображения станут небольшого объема, равными по ширине, почти без потери качества. Работает на управляемых формах для УТ 11, КА, ERP.

3000 руб.

21.07.2022    10163    10    4    

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

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

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

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

Обычные формы в веб-клиенте не доступны, соответственно, данный метод к ним неприменим. Замечу, что и при управляемых формах метод работает только в веб-клиенте, но не в тонком/толстом.
VyacheslavShilov; +1 Ответить
5. Glebis 13 21.07.17 14:14 Сейчас в теме
Передо мной стоит задача: отключать сессии неактивных пользователей. Ваша статья натолкнула меня на мысль - определять период "не активности" по времени без движения мыши.
Вопрос: можно ли добавив на обычную или управляемую форму (не веб интерфейс) рабочего стола элемент "ПолеHTMLДокумента" событием onmousemove сбрасывать таймер обработчика ожидания, который закрывает текущую сессию?
6. VitaliyCeban 467 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 1979 01.12.17 09:21 Сейчас в теме
8. VitaliyCeban 467 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 467 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 133 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 133 27.05.20 16:13 Сейчас в теме
Сработало, только top.document поменял просто на document, ибо не на всех сайтах у 1с есть доступ к самому сайту
Плюс автору
17. kild 93 19.11.21 04:20 Сейчас в теме
@VitaliyCeban
Если показывается окно авторизации, но вход еще не выполнен, то при закрытие браузера или переходе в "about:blank" сеанс с пользователем без имени так и останется висеть в активных пользователях.

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