如何修复 Guice 错误,“发生了非法的反射访问操作”

Mat*_*t R 11 guice kotlin java-11

我有一个 Kotlin 项目,它使用 Guice 进行 DI,最近从 JDK 8 -> 11 更新。它现在在运行时发出以下错误:

WARNING: An illegal reflective access operation has occurred
WARNING: Illegal reflective access by com.google.inject.internal.cglib.core.$ReflectUtils$1 (file:/Users/matt/.gradle/caches/modules-2/files-2.1/com.google.inject/guice/4.2.2/6dacbe18e5eaa7f6c9c36db33b42e7985e94ce77/guice-4.2.2.jar) to method java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int,java.security.ProtectionDomain)
WARNING: Please consider reporting this to the maintainers of com.google.inject.internal.cglib.core.$ReflectUtils$1
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
Run Code Online (Sandbox Code Playgroud)

应如何解决此警告?

Dan*_*ini 10

该问题是由于 Guice 内部访问 Java 对象的方式造成的,这在新的 (Java 9+) Java 模块系统下是不安全的。

另外,从 Java 16 开始,此警告变为错误,必须手动指定执行标志--illegal-access=permit才能重现 Java 9-15 的行为。

你无能为力来解决这个问题;最好的选择是升级到 Guice 5.0.1,该版本已打补丁以避免非法访问。您的警告将会消失,并且您的应用程序将在 Java 16+ 上以默认 JVM 行为运行。

  • 谢谢,更新到 5.0.1 后警告消失了。 (3认同)