💡
原文英文,约800词,阅读约需3分钟。
📝
内容提要
JEP 472提议限制将来的Java版本中JNI和FFM API的使用,以增强安全性和性能。该提议包括对JNI使用发出警告和调整FFM API。目标是要求开发人员对任何JNI和FFM API的使用进行明确批准。文章解释了JNI使用的风险,如内存损坏和绕过访问检查。提议建议采取分阶段的方法限制JNI的使用,并提供了启用本地访问的选项。文章还提到了一个新工具,jnativescan,用于帮助识别使用JNI的库。过渡到更严格的JNI限制可能需要进行调整,但将有助于构建更安全的Java生态系统。
🎯
关键要点
-
JEP 472提议限制未来Java版本中JNI和FFM API的使用,以增强安全性和性能。
-
该提议要求开发人员在启动时对JNI和FFM API的使用进行明确批准。
-
JNI的使用存在风险,如内存损坏和绕过访问检查,可能影响Java平台的完整性。
-
提议采取分阶段的方法限制JNI的使用,初期将对加载和链接本地库的操作发出警告。
-
开发人员可以通过命令行选项--enable-native-access启用特定Java代码的本地访问。
-
本地访问限制的影响可以通过--illegal-native-access选项进行控制,未来计划将默认行为设置为deny。
-
长期目标是通过默认拒绝来加强安全措施,确保Java平台的完整性。
-
新工具jnativescan将帮助识别使用JNI的库,促进开发人员的调整。
-
JEP 472标志着向更安全的Java平台迈出了重要一步,预计将带来显著的安全和完整性收益。
➡️