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

Описанный метод позволяет организовать контейнер средствами 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;

17 Comments

  1. sikuda

    Очень хорошо что появляются статьи на эту тему. Посмотреть как это работает, это нормально. Но так взаимодействовать с системой я бы не стал.

    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/. И как будет готово для применения — сразу опубликую.

    Reply
  2. Elisy

    (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й версией?

    Reply
  3. sikuda

    Я конечно не эксперт по 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

    Reply
  4. stanru1

    сдается мне, что если речь не идет о решении, которое будет сертифицироваться на «1с совместимо», то можно смело и к базе данных обращаться, и в ифрейме веб клиента запускать. Ибо лицензионное соглашение не есть закон. Впрочем, копий на эту тему сломано нимало.

    За статью огромный «плюс»; сомневаюсь, что данный механизм найдет практическое применение (ибо, действительно, 1с может в одночасье все поменять), но интересно и почетно!

    Reply
  5. Elisy

    (4) stanru1,

    сдается мне, что если речь не идет о решении, которое будет сертифицироваться на «1с совместимо», то можно смело и к базе данных обращаться, и в ифрейме веб клиента запускать. Ибо лицензионное соглашение не есть закон. Впрочем, копий на эту тему сломано нимало.

    Есть один момент. Внутри 1С через поле HTML документа этот механизм тоже доступен. Непонятно, как к этому относиться, ведь работа ведется через объекты 1С.

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

    Передача пароля через параметр javascript — убило.

    Пароль администратора с полными правами, я надеюсь, вы имели ввиду.

    Reply
  7. Elisy

    (6) opx,

    Передача пароля через параметр javascript — убило.

    Пароль администратора с полными правами, я надеюсь, вы имели ввиду.

    Не понятен сарказм. Вы думаете 1С передает логин и пароль каким-то более защищенным образом? 1С передает их сериализованными в base64 кодировку, что не намного защищеннее.

    Reply
  8. opx

    (7)1С хранит и передает не пароль, а хэш. SHA-1, если мне не изменяет память.

    За сарказм извините, но про передачу пароля через javascript забудьте.

    Reply
  9. Elisy

    (8) opx,

    веб-клиент 1С передает на сервер логин пароль в формате «логин:пароль» в формате base64. Во всяком случае так было в 8.2.15.

    Reply
  10. stanru1

    (8) opx, 1с даже предлагает типовой механизм авторизации в вебклиенте через post запрос. Описано в одной из жкк. Пароль из post запроса, разумеется, передается не зашифрованным.

    Reply
  11. opx

    Все проверил. Действительно так. web-клиент использует передачу пароля по http в base64. Я в шоке. Берем снифер и имеем полные права. 1С…. они такие 1С

    Reply
  12. Asmody

    гм… не понял, в чём соль статьи. в том, что можно сайты в iframe подгружать?

    Reply
  13. Asmody

    (11) opx, и что? защита передаваемых данных — это не задача веб-приложения. боитесь перехвата паролей — настраивайте SSL.

    Reply
  14. comol

    Вот люди заморочились…. Написали бы может 1C Webpart для Sharepoint? И ваши задачи бы решило и людям польза была бы :). Конечно интерфейс менять вряд ли кому интересно, но вот часть функциональности на корп портал вынести штатным образом с возможностью управления, а не стандартным html контейнером уже было бы интересно…

    Reply
  15. Asmody

    (14) comol, а веб-сервисов для этого недостаточно?

    Reply
  16. sikuda

    (1) По второму варианту использования в 1С html поля: Мой ответ Чембурлену Доминиканне http://infostart.ru/public/191248/ (на согласовании 19.06.2013 12:45) Рисование графики в HTML поле.

    Reply
  17. Pawlick

    Ставлю плюс за то, что вобщем все понял по форме, но ни хрена не понял по содержанию…:)

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *