15

我有一个 OSGI 应用程序,并且有大约 30 个包(jar 文件)。今天我决定看看它是如何工作的/它是否适用于 Java 9。

所以我开始了我的申请并得到了

WARNING: An illegal reflective access operation has occurred
WARNING: Illegal reflective access by org.apache.felix.framework.util.SecureAction (file:/home/.../jar/org.apache.felix.framework-5.4.0.jar) to method java.net.URLClassLoader.addURL(java.net.URL)
WARNING: Please consider reporting this to the maintainers of org.apache.felix.framework.util.SecureAction
WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations
WARNING: All illegal access operations will be denied in a future release

经过一番阅读,我添加了命令行选项

--add-exports java.base/java.net=org.apache.felix.framework 

并创建了具有以下内容的文件 module-info.java:

module org.apache.felix.framework { }

我有两个问题。我应该把这个 module-info.java 放在哪里让 jvm 读取它?我应该如何将此模块信息与org.apache.felix.framework-5.4.0.jar文件/捆绑包/jar绑定?

如果我做错了,请告诉我解决这个问题的正确方向。

4

3 回答 3

17

通用提示:

要回答您的具体问题:

模块声明( module-info.java) 需要进入您的源根目录 (例如) src/main/java。然后它必须在要编译的文件列表中,所以它会变成一个模块描述符module-info.class)。最后一步是将它包含在打包到 JAR 中的类文件列表中。(在 JAR 中包含模块描述符会将其转换为模块化 JAR。如果放置在模块路径上,JPMS 会将其转换为模块。)

如果您毕竟不想创建模块并希望您的代码在未命名的模块中运行,您可以允许它使用占位符访问内部 API ALL-UNNAMED- 如果您发出警告,您需要打开该包进行反射:

--add-opens java.base/java.net=ALL-UNNAMED

不过,更好的解决方案是停止使用内部 API。由于这不是您的代码,而是您的依赖项,因此您应该查找或打开 Apache Felix 的问题,要求删除对内部 API 的访问。

于 2017-09-05T21:21:38.193 回答
3

如果您要在 Java-9 上启动项目,那么Jigsaw 快速入门是一个不错的开始方式。

我应该把这个 module-info.java 放在哪里让 jvm 读取它?

从声明中推断您的模块名称module org.apache.felix.framework { },您应该将module-info.java文件放在您的项目目录中:

src/org.apache.felix.framework/module-info.java 

我应该如何将此模块信息与 org.apache.felix.framework-5.4.0.jar 文件/bundle/jar 绑定?

进一步编译模块和打包它们(在你的模块化 jar 的顶层目录绑定 module-info.class),你可以使用javacjar命令。

上面的示例命令有点像:

$ javac --module-path mods -d mods/org.apache.felix.framework \
    src/org.apache.felix.framework/module-info.java src/org.apache.felix.framework/com/apache/felix/framework/Application.java


$ jar --create --file=mlib/org.apache.felix.framework.jar \
    --main-class=com.apache.felix.framework.Application -C mods/com.apache.felix.framework

此外,您可以使用以下命令执行模块:

$ java -p mlib -m com.apache.felix.framework

除了状态模块系统和快速入门文档之外,对于将现有项目迁移到 Java-9,我建议您遵循JDK9 迁移指南,该指南明确说明了适应 Java9 所需的逐步过渡。

于 2017-09-06T02:26:29.067 回答
3

您应该向 Apache Felix 提交一个错误,因为它是 org.apache.felix.framework-5.4.0.jar 中的代码正在执行非法访问并且需要修复。我使用较新的版本 5.6.8 进行了快速测试,--illegal-access=debug并且似乎 Felix 有几个需要注意的问题。是的,您可以通过将 java.net 包打开为“ALL-UNNAMED”来暂时消除上述特定警告,但这只是一个或多个问题。

于 2017-09-06T08:25:31.267 回答