bdd2

Внешнее воздействие на веб-клиент 1С:Предприятие

Опубликовал Сергей Карташев (Elisy) в раздел Обмен - Интеграция с WEB

Описанный метод позволяет организовать контейнер средствами html и JavaScript и поместить в него веб-клиент 1С. При этом контейнеру доступно управление веб-клиентом, как на уровне алгоритмов, так и на уровне управления стилями. Подход отрабатывался на 1С версии 8.2.18.96.

Внешнее воздействие на веб-клиент 1С:Предприятие

Описанный метод позволяет организовать контейнер средствами html и JavaScript и поместить в него веб-клиент 1С. При этом контейнеру доступно управление веб-клиентом, как на уровне алгоритмов, так и на уровне управления стилями. Подход отрабатывался на 1С версии 8.2.18.96.

Настройка на стороне веб-сервера

Каждый веб-клиент 1С работает с опубликованной на веб-сервере информационной базой. Для более полной интеграции контейнер, в который будет встроен веб-клиент, необходимо создавать на этом же сервере. Это позволит избежать проблем с безопасностью, связанных с кросс-доменными обращениями. Например, Silverlight и Flash не позволяют обращаться к контенту других сайтов, если не настроены соответствующие политики в виде xml-файлов. Post-запросы между доменами также могут быть затруднительными.

Настройка Apache хранится в файле conf/httpd.conf

Изменить нужно значение путей. Ниже приведены значения для пути c:/Apache.www - в нем хранятся ссылки на информационные базы 1С.

DocumentRoot "C:/Apache.www"

<Directory "C:/Apache.www">

Предварительная настройка

Проект Html-файла лучше начать с готового шаблона, где прописаны стили на все случаи браузеров. Весьма достойный шаблон находится по адресу http://html5boilerplate.com/

Поместить его следует в корневой каталог документов, который был указан при настройке веб-браузера. За домашнюю страницу сейчас отвечает файл index.html - его нужно править.

На всякий случай выставляем режим совместимости браузера - совместимость с самым последним:

 

Используемый шаблон работает с jQuery.

Запуск веб-клиента 1С будет происходить в IFrame внутри index.html. Первая кнопка будет отвечать за запуск приложения 1С App, вторая - за запуск приложения NetBridge.


    
    
    

Обработчик нажатий на кнопки выглядит таким образом:

$(document).ready(function () {
    $("#appButton").click(function () {
        $("#iframe").attr("src", "App/ru_RU/?N=Администратор");
    });

    $("#netBridgeButton").click(function () {
        $("#iframe").attr("src", "NetBridge/ru_RU/?N=Сергей");
    });
...

На этом этапе можно воздействовать на параметры запуска веб-клиента. Например, передать имя пользователя (N=Администратор) и пароль.

Реакция на события веб-клиента

Первое событие, которое необходимо отловить - это событие, когда веб-клиент 1С загрузился и готов к использованию.

IFrame реализует событие на которое можно подписаться. Проблема заключается в том, что для веб-клиента может вызываться до 3х раз. такой вызов связан с перенаправлениями, например, веб-клиент 1С перенаправляет веб-клиент с учетом языка пользователя. Опытным путем удалось установить, что последний вызов связан с появлением объекта WebUI в веб-клиенте. Но процесс инициализации 1С на этом не закончен. На этом этапе не подгружены нужные библиотеки и не создан интерфейс главной формы. За признак создания главного интерфейса можно взять момент, когда переменная initialized станет равна true.

К переменным веб-клиента 1С можно обращаться через конструкцию:

cw = $("#iframe").get(0).contentWindow;

Обработчики будут выглядить так:

$(document).ready(function () {
    ...
    $('#iframe').load(function () {
        //Вызовы происходят несколько раз. Они связаны с переадресацией на ru_RU, например
        if ("WebUI" in $("#iframe").get(0).contentWindow) {
            var cw = $("#iframe").get(0).contentWindow;

            setTimeout(function () {
                desktopLoadedComplete();
            }, 50);
        }
    });
});

В результате цепочки событий будет вызвана функция desktopLoadedComplete:

desktopLoadedComplete = function () {
    var cw = $("#iframe").get(0).contentWindow;
    if ($("#iframe").get(0).contentWindow.Web.Application.initialized) {
         //alert(cw.Web.Common.Version);
         themes = cw.winManager.controls["themes"];
         themes.setListener(handleEvents);

         $('span.themeLink', $("#iframe").contents()).css('text-decoration', 'line-through');
    }
    else {
         setTimeout(function () {
             desktopLoadedComplete();
        }, 50);
    }
}

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

$('span.themeLink', $("#iframe").contents()).css('text-decoration', 'line-through');

За окно разделов отвечает объект winManager.controls["themes"] типа WebUI.ThemesPanel. Этот тип наследован от WebUI.NavigationControl, который в свою очередь наследован от WebUI.Control и Web.Events.EventsBase.

Опытным путем удалось подключиться к событию переключения раздела. Выглядит это так:

themes = cw.winManager.controls["themes"];
themes.setListener(handleEvents);

В обработчик событий handleEvents поступает несколько параметров, среди которых - источник события, код события. Для анализа переключения разделов обработчик будет таким:

handleEvents = function (sender, eventId, data0) {
    var cw = $("#iframe").get(0).contentWindow;
    if (eventId == cw.Web.Events.UIThemeButtonClickedEvent) {
        alert("eventId = Web.Events.UIThemeButtonClickedEvent");

        cw.winManager.handleEvents(sender, eventId, data0);
    }
}

При переключении раздела будет вызвано диалоговое окно и передано управление родному обработчику событий 1С.

Выводы

Html, JavaScript и jQuery предоставляют мощные средства для управления веб-клиентом 1С извне. Доступны передача параметров (логин, пароль), управление оформлением и стилями, подписка на события. Веб-клиент 1С содержит мощный фреймворк, который требует долгого времени, чтобы разобраться с ним.

В статье не охвачена операция вызова серверных и клиентских процедур, но такая возможность теоретически есть.

Статья интересна также при использовании поля HTML на веб-клиенте без предложенной технологии. Так как в этом случае вся инфраструктура 1С также доступна через родительское окно. В теории при вызове в таком контексте серверных процедур можно организовать взаимодействие между пользовательским html-кодом и родными элементами управления 1С. Такой вариант - альтернатива использованию WebBrowser Control, что означает отвязку от Windows.

//

&amp;amp;amp;amp;lt;div&amp;amp;amp;amp;gt;&amp;amp;amp;amp;lt;img src="//mc.yandex.ru/watch/21031318" style="position:absolute; left:-9999px;" alt="" /&amp;amp;amp;amp;gt;&amp;amp;amp;amp;lt;/div&amp;amp;amp;amp;gt;

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

Наименование Файл Версия Размер
Исходный код веб-сайта
.zip 86,88Kb
14.06.13
25
.zip 86,88Kb 25 Скачать

См. также

Добавить вознаграждение
Комментарии
1. Сергей Кудашкин (sikuda) 468 16.06.13 15:26 Сейчас в теме
Очень хорошо что появляются статьи на эту тему. Посмотреть как это работает, это нормально. Но так взаимодействовать с системой я бы не стал.
1. 1С в любое время изменит код на который вы основываетесь.
2. Лицензирование 1С говорит вам нет. v8.1c.ru/predpriyatie/questions_licence.htm#64
И проблему старого движка не решается, у вас в тонком клиенте будут выскакивать ошибки.

Собственно нам тогда остается два пути(мое мнение).
1. Использовать гибкий универсальный web-сервис. Типа http://infostart.ru/public/180203/ и http://infostart.ru/public/189876/(будущее). Остаются проблемы с лицензированием каждого пользователя(это везде в 1С) и производительностью, что можно и нужно обсудить...
2. Использовать html поле внутри 1С, а это и есть контейнер iframe внутри движка. И здесь главное найти инструменты работоспособные как со старым движком 1С, как и с любым современным. Я копаюсь в современной графике http://infostart.ru/public/174856/. И как будет готово для применения - сразу опубликую.
2. Сергей Карташев (Elisy) 835 16.06.13 15:58 Сейчас в теме
(1) sikuda,
Есть разные мнения на этот счет
1. 1С в любое время изменит код на который вы основываетесь.

Компании 1С очень сложно поддерживать код сразу для всех браузеров, учитывая, что она сочинила свой фреймворк. Это значит, что мало кто захочет лезть в уже отлаженный и работающий код на JavaScript.
2. Лицензирование 1С говорит вам нет. v8.1c.ru/predpriyatie/questions_licence.htm#64

Пункт можно трактовать по разному. В основном речь идет о СУБД. Все работы ведутся через объекты 1С, определенные в JavaScript.

У вас отличные статьи. Не подскажете следующий пункт в 8.3.3:
Веб-клиент. Системные требования. Прекращена поддержка веб-браузеров:
Microsoft Internet Explorer версии 7.0;
Это значит, что html-поле и веб-клиент будут запускаться в режиме совместимости с 8й версией?
3. Сергей Кудашкин (sikuda) 468 17.06.13 07:52 Сейчас в теме
Я конечно не эксперт по IE, но в средствах разработчика IE(F12) можно устанавливать различные режимы, эмулируя его работу со старыми версиями(типа настроек совместимости в 1С). Я поигрался с 1С http://sikuda.ru/internet-explorer-10-dlya-windows-7-vyishel/
1С переходит в режим:
<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7"/>

Про режимы совместимости IE можно почитать http://msdn.microsoft.com/ru-ru/library/ie/cc288325%28v=vs.85%29.aspx
4. Станислав Раташнюк (stanru1) 78 17.06.13 14:54 Сейчас в теме
сдается мне, что если речь не идет о решении, которое будет сертифицироваться на "1с совместимо", то можно смело и к базе данных обращаться, и в ифрейме веб клиента запускать. Ибо лицензионное соглашение не есть закон. Впрочем, копий на эту тему сломано нимало.
За статью огромный "плюс"; сомневаюсь, что данный механизм найдет практическое применение (ибо, действительно, 1с может в одночасье все поменять), но интересно и почетно!
5. Сергей Карташев (Elisy) 835 17.06.13 16:09 Сейчас в теме
(4) stanru1,
сдается мне, что если речь не идет о решении, которое будет сертифицироваться на "1с совместимо", то можно смело и к базе данных обращаться, и в ифрейме веб клиента запускать. Ибо лицензионное соглашение не есть закон. Впрочем, копий на эту тему сломано нимало.

Есть один момент. Внутри 1С через поле HTML документа этот механизм тоже доступен. Непонятно, как к этому относиться, ведь работа ведется через объекты 1С.
6. Павел Опарин (opx) 416 17.06.13 16:41 Сейчас в теме
Html, JavaScript и jQuery предоставляют мощные средства для управления веб-клиентом 1С извне. Доступны передача параметров (логин, пароль)

Передача пароля через параметр javascript - убило.
Пароль администратора с полными правами, я надеюсь, вы имели ввиду.
7. Сергей Карташев (Elisy) 835 17.06.13 18:16 Сейчас в теме
(6) opx,
Передача пароля через параметр javascript - убило.
Пароль администратора с полными правами, я надеюсь, вы имели ввиду.

Не понятен сарказм. Вы думаете 1С передает логин и пароль каким-то более защищенным образом? 1С передает их сериализованными в base64 кодировку, что не намного защищеннее.
8. Павел Опарин (opx) 416 17.06.13 22:46 Сейчас в теме
(7)1С хранит и передает не пароль, а хэш. SHA-1, если мне не изменяет память.
За сарказм извините, но про передачу пароля через javascript забудьте.
9. Сергей Карташев (Elisy) 835 18.06.13 02:21 Сейчас в теме
(8) opx,
веб-клиент 1С передает на сервер логин пароль в формате "логин:пароль" в формате base64. Во всяком случае так было в 8.2.15.
10. Станислав Раташнюк (stanru1) 78 18.06.13 10:34 Сейчас в теме
(8) opx, 1с даже предлагает типовой механизм авторизации в вебклиенте через post запрос. Описано в одной из жкк. Пароль из post запроса, разумеется, передается не зашифрованным.
11. Павел Опарин (opx) 416 18.06.13 11:34 Сейчас в теме
Все проверил. Действительно так. web-клиент использует передачу пароля по http в base64. Я в шоке. Берем снифер и имеем полные права. 1С.... они такие 1С
12. Asmody (Asmody) 18.06.13 14:18 Сейчас в теме
гм… не понял, в чём соль статьи. в том, что можно сайты в iframe подгружать?
13. Asmody (Asmody) 18.06.13 14:20 Сейчас в теме
(11) opx, и что? защита передаваемых данных — это не задача веб-приложения. боитесь перехвата паролей — настраивайте SSL.
14. Олег Филиппов (comol) 2665 18.06.13 14:51 Сейчас в теме
Вот люди заморочились.... Написали бы может 1C Webpart для Sharepoint? И ваши задачи бы решило и людям польза была бы :). Конечно интерфейс менять вряд ли кому интересно, но вот часть функциональности на корп портал вынести штатным образом с возможностью управления, а не стандартным html контейнером уже было бы интересно...
15. Asmody (Asmody) 18.06.13 16:52 Сейчас в теме
(14) comol, а веб-сервисов для этого недостаточно?
16. Сергей Кудашкин (sikuda) 468 19.06.13 12:51 Сейчас в теме
(1) По второму варианту использования в 1С html поля: Мой ответ Чембурлену Доминиканне http://infostart.ru/public/191248/ (на согласовании 19.06.2013 12:45) Рисование графики в HTML поле.
17. Pawlik (Pawlick) 19.06.13 16:46 Сейчас в теме
Ставлю плюс за то, что вобщем все понял по форме, но ни хрена не понял по содержанию...:)