【问题标题】:Spring Dependency Injection by Constructor - Error creating bean, caused by: java.lang.IncompatibleClassChangeError构造函数的 Spring 依赖注入 - 创建 bean 时出错,原因是:java.lang.IncompatibleClassChangeError
【发布时间】:2018-05-30 02:47:27
【问题描述】:

我刚开始学习 Spring 框架。我正在通过 Constructor 学习 Spring Dependency Injection,并在尝试运行代码时遇到了这个错误。请帮助我解决此错误并解释导致此错误发生的原因。谢谢。

这是我的代码:

ActiveMQMessage.java

package com.infotech;

public class ActiveMQMessage {

    public void sendMessage() {
        System.out.println("Send message via ActiveMQMessage..");
    }
}

Communication.java

package com.infotech;

public class Communication {

    private ActiveMQMessage activeMQMessage;

    public Communication(ActiveMQMessage activeMQMessage) {
        super();
        this.activeMQMessage = activeMQMessage;
    }

    public void communicate() {
        activeMQMessage.sendMessage();
    }
}

applicationContext.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
   http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">

    <bean id="communication" class="com.infotech.Communication">
        <constructor-arg name="activeMQMessage" ref="activeMQMessage"></constructor-arg>
    </bean>

    <bean id="activeMQMessage" class="com.infotech.ActiveMQMessage"></bean>

</beans>

Main.java

package com.infotech;

import org.springframework.context.support.AbstractApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class Main {

    public static void main(String[] args) {

        AbstractApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");

        Communication communication = context.getBean("communication", Communication.class);

        communication.communicate();

        context.close();
    }
}

这是错误:

Mei 30, 2018 9:13:55 AM org.springframework.context.support.ClassPathXmlApplicationContext prepareRefresh
INFO: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@3830f1c0: startup date [Wed May 30 09:13:55 ICT 2018]; root of context hierarchy
Mei 30, 2018 9:13:55 AM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
INFO: Loading XML bean definitions from class path resource [applicationContext.xml]
Mei 30, 2018 9:13:55 AM org.springframework.context.support.ClassPathXmlApplicationContext refresh
WARNING: Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'communication' defined in class path resource [applicationContext.xml]: Unexpected exception during bean creation; nested exception is java.lang.IncompatibleClassChangeError: class org.springframework.core.LocalVariableTableParameterNameDiscoverer$ParameterNameDiscoveringVisitor has interface org.springframework.asm.ClassVisitor as super class
Exception in thread "main" org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'communication' defined in class path resource [applicationContext.xml]: Unexpected exception during bean creation; nested exception is java.lang.IncompatibleClassChangeError: class org.springframework.core.LocalVariableTableParameterNameDiscoverer$ParameterNameDiscoveringVisitor has interface org.springframework.asm.ClassVisitor as super class
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:514)
    at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:317)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:228)
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:315)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199)
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:760)
    at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:869)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:550)
    at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:144)
    at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:85)
    at com.infotech.Main.main(Main.java:10)
Caused by: java.lang.IncompatibleClassChangeError: class org.springframework.core.LocalVariableTableParameterNameDiscoverer$ParameterNameDiscoveringVisitor has interface org.springframework.asm.ClassVisitor as super class
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(Unknown Source)
    at java.security.SecureClassLoader.defineClass(Unknown Source)
    at java.net.URLClassLoader.defineClass(Unknown Source)
    at java.net.URLClassLoader.access$100(Unknown Source)
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.net.URLClassLoader$1.run(Unknown Source)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at org.springframework.core.LocalVariableTableParameterNameDiscoverer.inspectClass(LocalVariableTableParameterNameDiscoverer.java:116)
    at org.springframework.core.LocalVariableTableParameterNameDiscoverer.getParameterNames(LocalVariableTableParameterNameDiscoverer.java:89)
    at org.springframework.core.PrioritizedParameterNameDiscoverer.getParameterNames(PrioritizedParameterNameDiscoverer.java:67)
    at org.springframework.beans.factory.support.ConstructorResolver.autowireConstructor(ConstructorResolver.java:189)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireConstructor(AbstractAutowireCapableBeanFactory.java:1270)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1127)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:541)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:501)
    ... 10 more

【问题讨论】:

  • 请注意,XML 配置通常被认为是老式的,而 Java 配置(更好的是 Boot)是首选。也就是说,注入 message 对象并不常见。通常,您会注入一个队列或其他类型的长期连接,然后调用带有消息(短期)的方法来发送。
  • 尝试在Communication 类构造函数中删除super()
  • @Mavlarn 我尝试删除 super() 但仍然遇到相同的错误。我最终将 spring 库从 spring-framework-5.0.5 更改为 spring-framework-4.2.6 并且错误消失了。

标签: java spring spring-mvc dependency-injection constructor


【解决方案1】:

我至少会尝试从&lt;constructor-arg&gt; 中删除name= 属性。如果只有一个可能匹配的构造函数,则这不是绝对必要的,虽然您所拥有的似乎应该可以工作,但错误消息似乎确实表明与名称解析有关。

【讨论】:

    【解决方案2】:

    com.spring.core 和 com.spring.asm jar 文件在您的项目中必须是不同的版本。 asm jar 很久没有更新了,所以你需要降级你的核心 jar 文件。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2011-02-02
      • 2021-08-14
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-06-23
      • 2012-03-09
      相关资源
      最近更新 更多