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

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/

См. также

SALE! 15%

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

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

8400 7140 руб.

20.08.2024    8062    60    28    

70

Инструменты администратора БД Роли и права Системный администратор Программист Пользователь 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

16800 руб.

06.12.2023    8946    42    5    

74

SALE! 15%

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

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

10000 8500 руб.

10.11.2023    10532    37    27    

62

SALE! 35%

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

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

4800 3120 руб.

14.01.2013    188178    1141    0    

912

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

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

14400 руб.

29.04.2020    32759    106    152    

73

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

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

6000 руб.

06.11.2012    72839    627    45    

85

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

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

4200 руб.

10.11.2015    62859    94    59    

79

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

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

3000 руб.

21.07.2022    9863    7    4    

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

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

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

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

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