Лучшее решение для использования EJB из Excel

Мы хотели бы предоставить доступ к некоторым нашим EJB-компонентам из Excel. Цель состоит в том, чтобы предоставить API, который можно использовать из VBA.

Наши EJB - это в основном сеансовые компоненты без сохранения состояния, которые выполняют простые операции CRUD с POJO.

Некоторые возможные решения:

  • Предоставление EJB-компонентов как WebServices и создание DLL-библиотеки VB / C#, обертывающей их,
  • Использование Corba для доступа к EJB из C#,
  • Создание библиотеки COM, которая использует Java для доступа к EJB,

Указатели на фреймворки для этого решения или другие идеи приветствуются.

Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
1
0
917
6
Перейти к ответу Данный вопрос помечен как решенный

Ответы 6

Ответ принят как подходящий

Вы можете взглянуть на IIOP.NET, который решает эту проблему.

Если у вас есть довольно новый контейнер ejb, самым дешевым и простым должно быть предоставление bean-компонентов как веб-сервисов и их вызов из VB / C#. Для этого не требуется никаких дополнительных инструментов или библиотек.

Еще во времена VB6 / COM / DCOM мы использовали набор J-Integra для выполнения этой задачи. Однако у меня нет опыта работы с версией .NET.

Я очень рекомендую ИКВМ. Это байт-код Java для компилятора сборки .NET (например, JAR -> DLL), и я использовал его для создания живых ссылок JMX и слушателей на сервере автоматизации Excel. Вам не составит труда создать сборку .NET из ваших клиентских заглушек EJB и вспомогательных библиотек.

// Николай

Я работаю над проектом с открытым исходным кодом под названием XLLoop - эта структура позволяет вам предоставлять функции POJO как функции Excel.

Это состоит из:

  1. Надстройка Excel (XLL), которая обменивается данными по TCP с:
  2. Сервер / библиотека Java, которая вызывает методы Java.

Вы можете встроить этот сервер java-функций в EJB и развернуть его как часть вашего сервера приложений.

Спасибо за ответ, я разберусь, но это кажется очень интересным

Michel 11.05.2009 16:52

Вы можете попробовать Обба (я работаю над этим проектом):

Obba is a Java object handler for spreadsheet applications.

It provides a bridge between spreadsheets and Java classes, such that spreadsheets can be used as graphical user interface for Java libraries. Accessing your Java library form the spreadsheet requires no glue code (no VBA needed, no special Java code needed). Objects are instantiated by their original constructor. Constructors and methods are invoked using a "by name" reflection. A spreadsheet-specific factory method is not necessary. Obba provides the functions to handle objects in spreadsheets.

The Java virtual machine providing the add-in may run on the same computer or a remote computer - without any change to the spreadsheet, i.e., object referenced in the spreadsheet can reside on remote Java virtual machine.

Другие вопросы по теме