У меня есть библиотека C++ (myLibraryMd.lib/myLibraryMt.lib) и заголовочный файл myClass.h, который содержит объявление API, которые вызываются в классе/объекте myClass. Опубликованы и другие заголовки/API. Назовите их myClass2.h и т. д.
Я пытаюсь создать приложение Java и иметь возможность вызывать эти API C++ (включая создание экземпляров объектов myClass/myClass2).
Я рассмотрел для этого решение JNI, но не уверен, как я могу защитить библиотеки DLL. Я хотел бы предотвратить сценарий, при котором DLL может быть заменена или подделаны API.
Я рассмотрел возможность подписания dll и проверки ее хеша (жестко запрограммированного в интерфейсе) в интерфейсе Java, однако это не так. надежно, поскольку файлы Java могут быть восстановлены из приложения Java, и как только хэш определен, игра окончена.
Как я могу реализовать безопасное решение, гарантирующее, что приложение вызывает правильные библиотеки DLL?
/>Я являюсь частью команды, которая разрабатывает библиотеку/API C++, и мы публикуем их для групп разработчиков приложений. Таким образом, функцию безопасности необходимо будет интегрировать в интерфейсы/dll, опубликованные нашей командой
Подробнее здесь: https://stackoverflow.com/questions/792 ... pplication
Как безопасно вызывать API C++ из приложения Java? ⇐ JAVA
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение