Вызов Java-кода из C # COM DLL, который используется приложением WIN32? - PullRequest
4 голосов
/ 15 сентября 2009

У меня очень простая проблема. У меня есть приложение, которое написано в Delphi 2007 для WIN32. Он использует C # DLL, которая импортируется в проект через его COM-интерфейс, и простой прием, чтобы избежать регистрации COM-объекта. Но теперь у меня есть сгенерированный Java-файл .JAR, который я хочу вызвать из своего приложения. И хотя у меня есть доступ к Delphi и коду C #, у меня просто нет доступа к коду Java.

Я могу сделать две вещи. Либо я вызываю Java-класс из кода Delphi, который затем вызывается из кода C #, который вызывается снова из кода Delphi. Или я просто вызываю код Java прямо из C #. (Который снова вызывается из Delphi.)

Я знаю, что это сложная установка. Приложение Delphi содержит графический интерфейс и некоторые коммуникационные модули для некоторого специального оборудования. Для них нет драйверов .NET. Код C # предназначен для поддержки связи с базой данных и включает некоторую логику, связанную с CardSpace и другими параметрами безопасности. Класс Java - это сторонний модуль кодирования, который создается сторонней организацией, которая вычисляет специальный хэш-код для данных в базе данных и выполняет дополнительную обработку, которая контролирует еще одну часть оборудования.

Самая большая проблема: нет сетевых коммуникаций! Он будет работать на специальном компьютере, на котором не установлено сетевое оборудование. Это автономная система Windows XP. Хотя с COM, Java и .NET все в порядке, я не могу использовать никакие соединения TCP / IP в этой системе.

Это будет мой следующий проект, если я его приму. Уже сейчас у меня болит голова, поэтому я думаю, что упущу этот шанс, хотя в нем есть интересная смесь нескольких разных языков. Я думаю, что я просто скажу им, чтобы они потратили 6 цифр на покупку нового оборудования вместо того, чтобы тратить сумму в 5 цифр на 28 дней моей работы ...


Несколько подробностей о проекте, которым я могу поделиться:

Код Delphi может подключаться к системе УАТС через COM-порт, который он использует для отправки факсов, отправки и получения SMS-сообщений, а также для получения простых команд, просто вводя цифры с телефона после вызова. Вся система имеет было написано для этого, все на основе кода WIN32.

Java-код является клиентским модулем для связи с робототехнической системой, которая контролирует среду, обрабатывает несколько деликатных объектов и выполняет постоянные измерения этих объектов. Это на Java, поэтому он не зависит от платформы. Связь между Java-клиентом и роботизированным оборудованием осуществляется через сеть, и сетевое оборудование / драйверы не любят дополнительной болтовни в этой сети. (Именно поэтому он отключен в максимально возможной степени. Даже Windows не будет получать обновления.)

Код C # предназначен для сбора данных из модуля Java и для фактического сохранения этих записей в памяти при записи обычных резервных копий в XML на случай, если что-то случится. Он предназначен для связи с модулем Java и несколькими другими модулями, которые обрабатывают сложные вычисления, написанные на .NET-совместимом доменном языке, который этот клиент разработал самостоятельно. Эти модули не поддерживают COM, поэтому оболочка c #.

Клиенту теперь нужен оператор, чтобы находиться рядом с оборудованием, чтобы манипулировать робототехникой. Он может либо модернизировать аппаратное обеспечение, что обойдется ему довольно дорого, но это даст ему лучший удаленный доступ, который стоит около 250 000 евро для замены древней робототехники и другого оборудования, или он платит нескольким разработчикам десятую часть этой суммы, чтобы получить свое текущее оборудование делать то же самое. Лично я думаю, что он не должен быть таким дешевым человеком, он просто хочет оценить, сколько будет стоить ему решение для разработчиков. Изменения кода невелики, так как большая часть функциональности уже есть. Это просто объединяет все это без какой-либо связи TCP / IP, что делает его более сложным.

По сути, инструкции, которые они хотят дать, - это ускорить или замедлить работу, отправлять случайные отчеты и отправлять SMS-предупреждения в случае возникновения проблем. Теперь они сидят рядом с экраном и пьют кофе целый день, читая какие-то газеты или другие журналы. И хотя это забавно в течение нескольких дней, он не может найти кого-то, кто хочет делать это все время, 24/7. (Да, они работают днем ​​и ночью, включая выходные.)

По сути, это все, что я знаю сам. Я даже не видел ПК, на котором он должен быть установлен, но некоторые из них настроены одинаково, поэтому я смогу поэкспериментировать с ним, как только это понадобится. (И это будет адский отладчик тоже.)


В заключительной заметке я представил смету расходов и набрал достаточно большое число, чтобы убедить моего потенциального работодателя вместо этого выполнить обновление оборудования. Дороже, но это сохранит надежность.

Из-за этого этот Q только что стал академическим ...

Ответы [ 4 ]

4 голосов
/ 15 сентября 2009

Другой вариант будет IKVM . Это реализация Java для .NET. Пожалуйста, посмотрите на этот связанный вопрос , ответы на который могут вам помочь.

2 голосов
/ 16 сентября 2009

JNBridge предоставляет мост Java-to-.NET (и наоборот). Это коммерчески поддерживается, относительно дешево, и работает хорошо. Это низкая задержка и не требует TCP / IP или сетевых коммуникаций. Вам не нужен доступ к коду Java для вызова его из .NET через мост.

1 голос
/ 31 октября 2009

Я являюсь автором jni4net , внутрипроцессного моста с открытым исходным кодом между JVM и CLR. Он построен на основе JNI и PInvoke. Код C / C ++ не требуется. Надеюсь, это поможет вам.

1 голос
/ 15 сентября 2009

Независимо от того, установлено ли какое-либо сетевое аппаратное обеспечение , вполне вероятно, что автономная система Windows XP все еще будет иметь локальную доступную сеть TCP / IP. У вас могут быть программы, прослушивающие порт TCP по адресу localhost (127.0.0.1), и другие службы подключаются к ним для обмена информацией по любому выбранному вами протоколу. HTTP с REST может быть подходящим выбором.

Вероятно, это будет гораздо менее болезненно, чем пытаться объединить все эти технологии вместе в одной программе Franken.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...