zoukankan      html  css  js  c++  java
  • Spring Boot 警告:An illegal reflective access operation has occurred

    Spring Boot 警告:An illegal reflective access operation has occurred

    问题描述

    最新将Spring Boot项目升级到JDK 11,运行时发现警告如下:

    WARNING: An illegal reflective access operation has occurred
    WARNING: Illegal reflective access by org.springframework.cglib.core.ReflectUtils (file:/D:/Android/.gradle/caches/modules-2/files-2.1/org.springframework/spring-core/5.2.0.RELEASE/e0e1b3c304f70ed19d7905975f6f990916ada219/spring-core-5.2.0.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

    20191021205420.png

     

    解决方案

     

    方案一

    增加 JVM 启动参数:

    java --illegal-access=deny

    Java 9 中这个参数默认是:permit

    20191021205515.png

     

    方案二

    在启动类增加以下方法,亲测试 jdk 11 有效

    public static void disableWarning() {
        try {
            Field theUnsafe = Unsafe.class.getDeclaredField("theUnsafe");
            theUnsafe.setAccessible(true);
            Unsafe u = (Unsafe) theUnsafe.get(null);
    
            Class cls = Class.forName("jdk.internal.module.IllegalAccessLogger");
            Field logger = cls.getDeclaredField("logger");
            u.putObjectVolatile(cls, u.staticFieldOffset(logger), null);
        } catch (Exception e) {
            // ignore
        }
    }

    启动 Spring Boot 时调用一下上面的方法

    public static void main(String[] args) {
        disableWarning(); //禁用警告
        SpringApplication.run(AppApplication.class, args);
    }
     

    参考

    参考:
    https://stackoverflow.com/questions/46454995/how-to-hide-warning-illegal-reflective-access-in-java-9-without-jvm-argument
    https://blog.csdn.net/qq_25958497/article/details/87258748
    https://stackoverflow.com/questions/53790182/get-the-current-value-of-illegal-access-setting-in-java

     

    处理“Error:(11, 25) java: 程序包jdk.internal.misc不存在” 的问题

    方案一: 把jdk 切换为 1.8版本

     

     

     方案二:

    编译时添加参数
    --add-exports java.base/jdk.internal.misc=ALL-UNNAMED
    运行时添加参数
    --add-opens java.base/jdk.internal.misc=ALL-UNNAMED
    
    
     
     
     
     
     
     
     
    为人:谦逊、激情、博学、审问、慎思、明辨、 笃行
    学问:纸上得来终觉浅,绝知此事要躬行
    为事:工欲善其事,必先利其器。
    态度:道阻且长,行则将至;行而不辍,未来可期
    转载请标注出处!
  • 相关阅读:
    webIDE 第二篇博文
    前端第一天
    记昨天
    入职第四天
    入职第二天
    linux常用命令,自己总结
    一切从头开始
    在服务器上搭建SVN
    Dynamic CRM 365学习历程--JS
    Dynamic CRM 365学习历程--有关CRM的学习过程种需要注意的事项
  • 原文地址:https://www.cnblogs.com/ios9/p/14586354.html
Copyright © 2011-2022 走看看