java.lang.NoSuchMethodError:org.springframework.core.annotation.AnnotatedDelementUtils.findMergedAnnotation

java.lang.NoSuchMethodError:org.springframework.core.annotation.AnnotatedDelementUtils.findMergedAnnotation,java,spring,spring-mvc,spring-jdbc,nosuchmethoderror,Java,Spring,Spring Mvc,Spring Jdbc,Nosuchmethoderror,运行服务器时,控制台上出现以下错误: Error creating bean with name org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMa pping#0': Invocation of init method failed; nested exception is java.lang.NoSuchMethodError: org.springframework.cor

运行服务器时,控制台上出现以下错误:

Error creating bean with name  
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMa
pping#0': Invocation of init method failed; nested exception is 
java.lang.NoSuchMethodError:    
org.springframework.core.annotation.AnnotatedElementUtils.findMergedAnnotation
(Ljava/lang/reflect/AnnotatedElement;Ljava/lang/Class;)Ljava/lang/annotation/Annotation;
网页上的404错误。我已经检查了url和资源是否存在

以下是我的xml:

springservlet.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc" 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.xsd
    http://www.springframework.org/schema/context 
    http://www.springframework.org/schema/context/spring-context.xsd
    http://www.springframework.org/schema/mvc
    http://www.springframework.org/schema/mvc/spring-mvc.xsd">

<context:component-scan base-package="com.abhishek"></context:component-scan>

<mvc:annotation-driven></mvc:annotation-driven>

<bean id="" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix" value="/WEB-INF/views/"></property>
    <property name="suffix" value=".jsp"></property>
</bean>


<bean id="myDataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver" />
    <property name="url" value="jdbc:oracle:thin:@localhost:1521:XE"></property>
    <property name="username" value="system"></property>
    <property name="password" value="pass"></property>
</bean>

<bean id="myJDBC" class="org.springframework.jdbc.core.JdbcTemplate">
    <property name="dataSource" ref="myDataSource"></property>
</bean>


</beans>
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xmlns="http://java.sun.com/xml/ns/javaee"
   xsi:schemaLocation="http://java.sun.com/xml/ns/javaee     http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
  id="WebApp_ID" version="2.5">
  <display-name>EmployeeDetails</display-name>
  <servlet>
      <servlet-name>employeermvc</servlet-name>
      <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

    <load-on-startup>1</load-on-startup>
   </servlet>

   <servlet-mapping>
       <servlet-name>employeermvc</servlet-name>
       <url-pattern>/</url-pattern>
   </servlet-mapping>

   <listener>
       <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
   </listener>

   <context-param>
       <param-name>contextConfigLocation</param-name>
       <param-value>/WEB-INF/spring-servlet.xml</param-value>
   </context-param>
</web-app>
DAoImpl:

package com.abhishek.Dao;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Component;

import com.abhishek.bean.Employee;

@Component
public class EmployeeDaoImpl implements EmployeeDao {

    @Autowired
    private JdbcTemplate jdbcTemplate;

    public EmployeeDaoImpl(){

    }

    public EmployeeDaoImpl(JdbcTemplate jdbcTemplate) {
       super();
       this.jdbcTemplate = jdbcTemplate;
    }

    @Override
        public void insert(Employee emp) {
        String sql="insert into employee(e_id,name,desig,deptt,basic) values(?,?,?,?,?)";
       jdbcTemplate.update(sql, emp.getEid(),emp.getName(),emp.getDesg(),emp.getDept(),emp.getBasic());
       System.out.println("Record Inserted!!!");
   }
}

这可能是因为多个相同的jar文件具有不同的版本。确保您没有使用不同版本的Spring的多个jar文件。

您的bean尚未配置。 在spring-servlet.xml中配置它

<bean id="employeeDao" class="com.abhishek.EmployeeDao">
    <property name="jdbcTemplate" ref="myJDBC"></property>
</bean>

还应研究以下事项

  • 检查您的JAR是否具有所需的方法
  • 检查同一个方法是否不能位于多个jar中,以便它们都尝试将其索引提供给jvm,&jvm混淆以选择正确的方法。
  • 列出您的JAR/依赖项删除不必要的
  • 使用maven下载所需的依赖项,或从spring.io/projects、grepcode下载
上一次我们需要jar,但我们没有需要的方法 可能是由于遗留等原因,因此请为其选择合适的jar


由于我多次在不同版本之间切换,是否有任何方法可以下载具有正确版本的所需JAR。这可能是问题所在。运行
mvn dependency:tree
,查找冲突的JAR。如果您仍然没有看到问题,请发布您的pom.xmlFYI:到目前为止发布的所有代码与具体问题完全无关。是的,问题已经解决。每个人提到的错误都是因为JAR的版本冲突。当我们发现类未找到或没有此类方法错误时,这些是我们需要检查的基本和必要的步骤。这些步骤是有成效的,但在这些步骤之后,我们多次遇到相同的问题是的,你是对的,但我们需要知道没有任何原因它背后的逻辑错误,这只是因为缺少或误解了jvm所需的属性。因此,通常我们需要检查这确实需要哪个jar。
<bean id="employeeDao" class="com.abhishek.EmployeeDao">
    <property name="jdbcTemplate" ref="myJDBC"></property>
</bean>