升级jdk11后出现告警信息解决方案,An illegal reflective access operation has occurred

告警信息:

WARNING: An illegal reflective access operation has occurred
WARNING: Illegal reflective access by org.springframework.cglib.core.ReflectUtils (file:/D:/dev/m2/org/springframework/spring-core/5.1.9.RELEASE/spring-core-5.1.9.RELEASE.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 org.springframework.cglib.core.ReflectUtils
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

解决方案:

启动类增加忽略非法反射告警:

package com.xxx.xxxx;

import java.lang.reflect.Field;
import java.lang.reflect.Method;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class XxxxApplication {

    public static void main(String[] args) {
        // 调用方法
        disableAccessWarnings(); // 忽略非法反射警告
        SpringApplication.run(XxxxApplication .class, args);
    }

    /**
     * 忽略非法反射警告 适用于jdk11
     */
    @SuppressWarnings("unchecked")
    public static void disableAccessWarnings() {
        try {
            Class unsafeClass = Class.forName("sun.misc.Unsafe");
            Field field = unsafeClass.getDeclaredField("theUnsafe");
            field.setAccessible(true);
            Object unsafe = field.get(null);

            Method putObjectVolatile =
                unsafeClass.getDeclaredMethod("putObjectVolatile", Object.class, long.class, Object.class);
            Method staticFieldOffset = unsafeClass.getDeclaredMethod("staticFieldOffset", Field.class);

            Class loggerClass = Class.forName("jdk.internal.module.IllegalAccessLogger");
            Field loggerField = loggerClass.getDeclaredField("logger");
            Long offset = (Long)staticFieldOffset.invoke(unsafe, loggerField);
            putObjectVolatile.invoke(unsafe, loggerClass, offset, null);
        } catch (Exception ignored) {
        }
    }
}

 

参考:忽略非法反射警告 An illegal reflective access operation has occurred_彦楠的博客-CSDN博客

<think>好的,我现在需要帮用户解决Retrofit 2.9.0的非法反射访问警告问题。首先,我要回忆一下这个问题的背景。Retrofit是一个广泛使用的HTTP客户端库,而Java 9之后引入了模块化系统,这可能导致旧版本的库在访问内部API时出现反射警告。用户提到的警告信息应该类似于“WARNING: Illegal reflective access by retrofit2.Platform...”。 接下来,我需要确认用户使用的Retrofit版本是2.9.0。这个版本可能依赖了旧版的OkHttp或者其他库,这些库可能在模块化环境中使用了反射。根据官方GitHub的Issue,比如问题#3341,Square团队应该已经讨论了这个问题,并提供了解决方案解决方案可能包括升级到更高版本的Retrofit,因为后续版本可能已经修复了这个问题。比如,Retrofit 2.10.0或更高版本可能更新了依赖,避免使用有问题的反射代码。另外,检查Java的版本也很重要,如果用户使用的是Java 11或更高,可能需要调整JVM参数来抑制警告,比如添加`--add-opens`参数。 还需要考虑依赖管理,比如确保OkHttp的版本与Retrofit兼容,并且没有引入其他过时的依赖。Maven或Gradle的依赖树分析可能会有帮助。此外,用户可能需要配置编译器选项或运行时参数来处理这些警告,如果暂时无法升级库的话。 最后,生成相关问题时要覆盖常见的情况,比如升级步骤、依赖管理、JVM参数设置和长期解决方案。确保回答结构清晰,步骤明确,并且引用官方资源以增加可信度。</think>关于Retrofit 2.9.0非法反射访问警告的解决方案如下: ### 问题原因 该警告源于Java 9+模块化系统对反射访问权限的严格限制,Retrofit早期版本通过反射访问JDK内部类$JacocoAgent时触发了该限制[^1]。 ### 解决步骤 1. **升级Retrofit版本** 推荐升级至2.11.0+版本: ```gradle implementation 'com.squareup.retrofit2:retrofit:2.11.0' ``` 新版已通过重构代码移除问题反射调用[^1] 2. **检查OkHttp兼容性** 确保使用配套的OkHttp 4.x: ```gradle implementation 'com.squareup.okhttp3:okhttp:4.12.0' ``` 3. **JVM参数临时方案(不推荐)** 在启动参数添加: ```bash --add-opens=java.base/java.lang=ALL-UNNAMED ``` 4. **检查Jacoco配置** 如果使用代码覆盖率检测工具,更新jacoco到0.8.7+版本 ### 验证方式 运行单元测试时观察日志,应不再出现以下警告: ``` WARNING: Illegal reflective access by retrofit2.Platform... ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值