Новая версия 1С:Предприятие 8.2 конфликтует с C# и .Net framework

15.12.10

Разработка - Разработка внешних компонент

Суть конфликта 1С 8.2 с C# и .Net framework в следующем. В версии 8.2 1С анонсировала новый способ написания внешних компонент 1С с использованием так называемого Native API. Самое интересное, что на C# предложенный подход реализовать невозможно, а реализация Native API на VC++/CLI теоретически возможна, но при попытке подключения DLL, скомпилированных с опцией /CLR, происходит зависание 1С (версия 8.2.13.202). Еще один конфликт – в новой версии 1С нет поддержки технологии ActiveX, на основе которой многие разработчики вставляли в формы 1С свои WinForms-приложения.

Многие слышали о выходе новой версии 1С:Предприятие 8.2 и знают о планах отказаться от поддержки 8.1 в первом квартале 2011 года. Мое мнение – 1С 8.2 – это сырой недоработанный продукт, который можно отнести к пре-бета/бета стадии. А с 8.1 разработчикам проще перейти на Asp.Net (например, через Elisy LinqTo1C), чем на управляемые формы 8.2. К такому выводу я пришел после 2 недельной попытки перевести наши .Net-проекты с версии 8.1 на более новую версию 1С 8.2. Заметка эта написана больше не для критики, а чтобы определить новую для определенного круга .Net-разработчиков проблему, попытаться донести ее до 1С и постараться совместно решить в текущей или новых версиях популярного продукта 1С:Предприятие 8.2.

Суть конфликта 1С 8.2 с C# и .Net framework в следующем. В версии 8.2 1С анонсировала новый способ написания внешних компонент 1С с использованием так называемого Native API. Самое интересное, что на C# предложенный подход реализовать невозможно, а реализация Native API на VC++/CLI теоретически возможна, но при попытке подключения DLL, скомпилированных с опцией /CLR, происходит зависание 1С (версия 8.2.13.202). Еще один конфликт – в новой версии 1С нет поддержки технологии ActiveX, на основе которой многие разработчики вставляли в формы 1С свои WinForms-приложения.

Простейший способ воспроизвести проблему зависания: включить опцию /CLR на проект-пример от 1С про таймер NativeAPI. Зазиповать DLL вместе с файлом MANIFEST.xml в макет кофигурации 1С 8.2 и выполнить следующий код на форме:

&НаКлиенте
Процедура TestNativeApi(Команда)
    УстановитьВнешнююКомпоненту("ОбщийМакет.ElisyNetBridge4");
    Сообщить(ПодключитьВнешнююКомпоненту("ОбщийМакет.ElisyNetBridge4", "ElisyNetBridge", ТипВнешнейКомпоненты.Native));	
    TestNativeApiServer();
КонецПроцедуры

&НаСервере
Процедура TestNativeApiServer()
    Сообщить(ПодключитьВнешнююКомпоненту("ОбщийМакет.ElisyNetBridge4", "ElisyNetBridge", ТипВнешнейКомпоненты.Native));	
КонецПроцедуры

Комментируя код, относящийся к клиенту или серверу, можно понять, что проблема характерна как для клиента, так и для сервера.

Еще одна проблема – отказ от поддержки ActiveX на управляемых формах 1С 8.2. Раньше многие .Net-разработчики писали WinForms проекты, которые можно было вставлять на формы 1С в версии 8.1. Сейчас нужно использовать какие-то обходные маневры, чтобы добиться одинакового со старой версией результата.

Я не хочу сказать, что больше не осталось способов работать с .Net-проектами из 1С, я хочу показать, что новая версия 1С недружелюбно относится к .Net, ограничивая поддержку и переводя свои API на заведомо неподдерживаемый формат.

Последняя важная проблема – это отсутствие заявленной функциональности в технологии написания внешних компонент (ВК) для ВК на основе веб-браузера. Начал делать реализацию ВК для веб-клиента. Долго разобраться не мог, почему не работает, начал копать вглубь исходных кодов JScript. Оказалось функциональность в 1С просто недореализована. В 8.2.10.73 для веб-браузера в коде JScript на команды, например, writeValue, registerProfileAs, readValue стоят тупо заглушки. А addError - вместо того, чтобы выводить ошибку в окно сообщений, как в предыдущих версиях 1С - выводит модальное диалоговое окно. Такие ошибки можно находить в бета-версии, но никак не в официальном релизе.

См. также

Медиадисплей. Рекламный информационный монитор для покупателя.

Разработка внешних компонент POS терминал Рабочее место Розничная торговля Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Управление торговлей 10 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Розничная и сетевая торговля (FMCG) Рестораны, кафе и фаст-фуд Реклама, PR и маркетинг Управленческий учет Платные (руб)

Монитор покупателя может отображать текущую покупку на кассовом месте, показывать видеорекламу, баннеры, во время простоя разворачивать рекламу на весь экран. Можно использовать в качестве графического меню-борда в кафе и видеовывески. Управление выводом на телевизор через hdmi-приставку на базе Windows или Android. В качестве устройства отображения можно использовать Android-планшеты, фоторамки с Android, монитор любого Windows-компьютера, доступного по сети. Настраивается ЛЮБОЙ ДИЗАЙН экрана!

16800 руб.

30.05.2017    52105    34    69    

43

Внешняя компонента для сканирования (замена TWAIN-компоненты БСП) (Native Win 32/64)

Разработка внешних компонент Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Внешняя компонента позволяет работать c TWAIN-совместимым оборудованием (сканерами, камерами) . Полностью совместима со стандартной TWAIN-компонентой из БСП и может применяться как ее замена без изменения вызовов, при этом может работать с 64-разрядной платформой, а так же имеет расширенную функциональность, например, сохранение результата непосредственно в PDF без использования сторонних утилит. Прекрасно работает на сервере, тонком клиенте и веб-клиенте (проверена работа в браузерах Google Chrome, Mozilla Firefox и Microsoft Internet Explorer).

2400 руб.

12.05.2020    26244    131    99    

83

Внешняя компонента для подключения 1С к телефонии Asterisk

Разработка внешних компонент Телефония, SIP Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Внешняя компонента выполнена по технологии Native API для 1С 8.х, обеспечивает доступ к программным АТС Asterisk (FreePBX, Elastix) через AMI интерфейс. Через него можно управлять многими функциями Asterisk (определение номеров, перевод звонков, набор телефона и т. д.)

2400 руб.

04.05.2018    44977    117    64    

60

Внешняя компонента печати PDF (Native Win 32/64)

Разработка внешних компонент Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Внешняя компонента позволяет печатать PDF файлы непосредственно из 1С, не используя при этом сторонних программ. Прекрасно работает на сервере, тонком клиенте и веб-клиенте. Основана на проекте PDFium из состава проекта Chromium/Chrome

1500 руб.

17.09.2018    35081    104    123    

111

Мастер создания внешних компонент 1С (технология COM) для DELPHI 6/7/8/2005/2006/2007/2008/2010/XE/XE2/XE3

Разработка внешних компонент Платформа 1С v8.3 Платные (руб)

Средство для сверхбыстрой разработки внешних компонент 1С:Предприятия 7.7 и 8 по технологии COM на всех версиях DELPHI, начиная с 6.

2000 руб.

28.03.2013    54000    35    14    

68

QR-код с логотипом компании (обычная и управляемая форма)

Разработка внешних компонент Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

Как известно, стремление сделать свою рекламную продукцию запоминающейся и выделяющейся — верный путь к успеху. Сегодня, мы поговорим с вами о том, что можно сделать с обычным черно-белым QR-кодом, чтобы он стал более живым и привлекательным. Если вам не терпится попробовать сделать QR-код с логотипом компании, то эта обработка для вас!

2400 руб.

22.06.2016    30840    4    4    

8

Внешняя компонента 1С и С++. Продолжаем разговор.

Разработка внешних компонент Платформа 1С v8.3 Бесплатно (free)

А давайте запилим 8.3.26 до релиза, или оповещение с сервера...

19.02.2024    4039    starik-2005    28    

52

Внешние компоненты 1С и язык C++

Разработка внешних компонент Механизмы платформы 1С Платформа 1С v8.3 Бесплатно (free)

Некоторые практические аспекты создания внешних компонент на языке С++ для платформы 1С 8.3++.

26.01.2024    4781    starik-2005    32    

39
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
98. Elisy 948 19.03.12 12:34 Сейчас в теме
(97) TeMochkiN,
Ошибка скорее всего происходит из-за того, что в
http://infostart.ru/public/60232/
используется .Net Bridge 3 - предыдущей версии.
Для исслдования многопоточности вам, думаю, проще взять версию 4.0.3.1 и воспользоваться публикацией
http://infostart.ru/public/104926/
TeMochkiN; +1 Ответить
99. TeMochkiN 19.03.12 14:27 Сейчас в теме
100. umetex 11.08.12 20:26 Сейчас в теме
всем привет. я http://infostart.ru/profile/103245/. компоненту native api на шарпе получить удалось. кому надо - скайп promironov
105. Elisy 948 13.08.12 07:39 Сейчас в теме
(100) umetex,
всем привет. я http://infostart.ru/profile/103245/. компоненту native api на шарпе получить удалось. кому надо - скайп promironov

Отлично, что получилось. Лучше было бы, если вы напишите статью на эту тему. Заодно и баллов на Инфостарте заработаете за скачивания. Тема многим будет интересна. Ссылку на вашу публикацию я смогу добавить в статью.

Сергей, скорее всего, ты очищаешь ссылки при вызове метода Done. Попробуй для теста вообще не вызывать деструктор :) 

Все может быть. К сожалению проект с опытами у меня был утрачен. А функциональность Native API в полной мене не подходит для реализации .Net Bridge. Поэтому пока остаемся на COM API.
101. umetex 12.08.12 02:54 Сейчас в теме
точнее это workaround c# для 1c nativeApi компоненты c++/clr
102. umetex 12.08.12 03:39 Сейчас в теме
Суть конфликта 1С 8.2 с C# и .Net framework в следующем. В версии 8.2 1С анонсировала новый способ написания внешних компонент 1С с использованием так называемого Native API. Самое интересное, что на C# предложенный подход реализовать невозможно, а реализация Native API на VC++/CLI теоретически возможна, но при попытке подключения DLL, скомпилированных с опцией /CLR, происходит зависание 1С (версия 8.2.13.202). Еще один конфликт – в новой версии 1С нет поддержки технологии ActiveX, на основе которой многие разработчики вставляли в формы 1С свои WinForms-приложения.


Сергей, скорее всего, ты очищаешь ссылки при вызове метода Done. Попробуй для теста вообще не вызывать деструктор :)
103. umetex 12.08.12 03:41 Сейчас в теме
и насчёт ActiveX. Это закономерно, потому что управляемые формы вроде не поддерживают ActiveX-элементы. или я не прав?
104. Elisy 948 13.08.12 07:34 Сейчас в теме
(103) umetex,

Управляемые формы действительно не поддерживают ActiveX. Для обхода этого момента сейчас используют HTML-страницу со вставленным ActiveX. Насколько понимаю, такой подход работает в тонком, толстом клиенте и на IE.
106. Elisy 948 18.08.12 08:55 Сейчас в теме
Подтверждаю, что пользователю umetex удалось решить описанную в статье проблему, и его решение работает на моем компьютере без "зависаний" и "крэшей".
108. boffart 297 06.05.13 14:39 Сейчас в теме
(106) (103) umetex, Коллеги, случайо статьи по этому поводу не ожидается? Можно как либо исходники глянуть?
109. Elisy 948 06.05.13 15:19 Сейчас в теме
(108) boffart,
Мне, честно говоря, пока в Native API не будет аналога типа IDispatch тема не очень интересна. Исходники у меня не сохранились. Исходники получались так: к исходникам от 1С на С++ добавляется в свойствах проекта CLR-признак.
umetex , вроде, добился хороших достижений. Это говорит о том, что задача как минимум реализуемая.
107. TeMochkiN 18.08.12 11:34 Сейчас в теме
Ну может он опубликует свое решение, или это уже тайна?
112. Elisy 948 16.05.16 07:03 Сейчас в теме
(111) Serginio,
Что-то решение конкретной проблемы статьи не увидел там
114. Serginio 938 16.05.16 08:04 Сейчас в теме
(112) Вот задал вопрос http://ru.stackoverflow.com/questions/523386/%d0%92%d1%8b%d0%b7%d0%be%d0%b2-%d1%83%d0%bf%d1%80%d0%b0%d0%b2%d0%bb%d1%8f%d0%b5%d0%bc%d0%be­%d0%b3%d0%be-%d0%ba%d0%be%d0%b4%d0%b0-%d0%b8%d0%b7-%d0%bd%d0%b5%d1%83%d0%bf%d1%80%d0%b0%d0%b2%d0%bb%d1%8f%d0%b5­%d0%bc%d0%be%d0%b3%d0%be

Есть куча вариантов вызова управляемого кода из неуправляемого в Linux.
А создать обертку вокруг нетовских объектов не проблема. Все параметры сериализуются и передаются через массив байт. Ссылочные типы сохраняются в массиве (List) и передаются индексы на них. Освобождать можно сразу скопом.

Я думаю, что тебя это должно заинтересовать. Кстати ищу работу http://infostart.ru/job/resume/523385/
115. Elisy 948 16.05.16 11:23 Сейчас в теме
(114) Serginio,
наверняка, можно придумать обходной путь. Но появляется куча недостатков.
Идея Elisy .Net Bridge изначально была в бесшовной интеграции с .Net framework. Это означает:
1. Большинство задач можно реализовать через конфигуратор 1С не прибегая к Visual Studio.
2. Отладка проискходит также в отладчике 1С.

В случае перехода на ограниченный формат Native API эти преимущества теряются.
117. Serginio 938 16.05.16 13:48 Сейчас в теме
(115) Твоя разработка под Windows. Я говорю об использовании .Net Core под линукс. По функционалу сходная с твоей.
Кстати можно и события прикрутить .NET(C#) для 1С. Динамическая компиляция класса обертки для использования .Net событий в 1С через ДобавитьОбработчик или ОбработкаВнешнегоСобытия
116. premierex 204 16.05.16 12:31 Сейчас в теме
(0) в новой версии 1С нет поддержки технологии ActiveX. Формально - да, но обходные пути использования ActiveX объектов на управляемых формах всё же есть. Посмотрите, например, вот эту разработку ActiveX контейнер для управляемого интерфейса системы 1С:Предприятие. Разработана по COM-технологии без использования .NET.
119. premierex 204 16.05.16 14:30 Сейчас в теме
(118) Serginio, про WinForms и Wpf не слышал даже. Надо будет поизучать. Где-то я упустил, что речь о Linux идёт. Смутило, видимо, в описании упоминание об ActiveX, которые, как известно в Linux не работают. Или твоя статья как раз и описывает как их можно подружить? Если честно, просто не хватило терпения прочитать больше сотни комментов ))).
120. Serginio 938 16.05.16 14:45 Сейчас в теме
(119) Та статья под Windows. Но идея у меня прикрутить .Net и Java к 1С Linux через доступ из натива к манагед.
Просто у меня есть проблемы со знанием С++. А так я уже кучу ссылок нашел как вызвать управляемый код (.Net Core) из нативного кода
121. v77 160 22.05.16 15:29 Сейчас в теме
(120) ВК NativeAPI можно и на C# писать и на С и на ассемблере. Вот тут сам принцип http://infostart.ru/public/81644/
Я могу такое повторить и на C#, но мне оно не надо, т.к. на C# почти не пишу. Если это кому то надо, то я за скромное вознаграждение могу это сделать.
122. Serginio 938 22.05.16 16:54 Сейчас в теме
(121) На C# проблематично. Не забывай, что это управляемый код.
https://its.1c.ru/db/metod8dev#content:3221:hdoc

Есть варианты использования через C++ CLR
https://www.daniweb.com/programming/software-development/threads/393447/c-dll-in-c-help-please

Есть еще такой
http://jonxxx.me/13-metatrader/15-eksport-funktsij-iz-net-dll-c-dllexport-net-framework-v-metatrader

На чистом C# .Native ВК не написать. Но не в этом. Интерес был к использованию .Net Core
в том числе на Linux. И непросто ВК а использование любых классов .Net. Что не сложно, когда знаешь С++ CLI
123. v77 160 22.05.16 17:17 Сейчас в теме
Net core сильно отличается от .net? А где этот net core взять?
124. v77 160 22.05.16 17:26 Сейчас в теме
А на С# вк писать только одна проблема - экспорт функций из dll. Решается через ildasm и ilasm. остальное решается средствами самого языка c#
126. v77 160 22.05.16 17:48 Сейчас в теме
Я так понял оно ещё beta. Лет через пять бдет очень актуально :)
127. Serginio 938 22.05.16 18:54 Сейчас в теме
(126) Ты просто не все ссылки читаешь
Она не бетта, а уже релиз кандидат 2

https://github.com/aspnet/Home/wiki/Roadmap
Будущая работа

Следующие функции, к сожалению, не будет делать это в начальной RTM релиза. Мы предварительно планируем отгрузки их в первоначальном выпуске художественного после RTM, в течение Q3 * 2016:
• Базовая поддержка видео
• SignalR
• Веб-страница

* Ссылки на ежегодные четверти (Q1, Q2, Q3, Q4) являются календарь на основе





Еще
http://metanit.com/sharp/aspnet5/
Оставьте свое сообщение