【问题标题】:There is already bean method mapped已经映射了 bean 方法
【发布时间】:2014-07-01 08:42:32
【问题描述】:

我收到以下异常:

</pre></p><p><b>root cause</b> <pre>org.springframework.beans.factory.BeanCreationException: 
Error creating bean with name 'org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping#0': 
Invocation of init method failed; nested exception is java.lang.IllegalStateException: 
Ambiguous mapping found. Cannot map 'sdtm-controller' bean method 
public java.util.List&lt;java.lang.String&gt; com.sas.hls.clc.clinicalstandards.sdtm.SDTM_Controller.getVersions()
to {[/getVersions],methods=[GET],params=[],headers=[],consumes=[],produces=[],custom=[]}: 
There is already 'SDTM_Controller' bean method
public java.util.List&lt;java.lang.String&gt; com.sas.hls.clc.clinicalstandards.sdtm.SDTM_Controller.getVersions() mapped.
    org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1486)
    org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:524)
    org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:461)
    org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:295)
    org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:223)
    org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:292)
    org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:194)
    org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:607)
    org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:932)
    org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:479)
    org.springframework.web.servlet.FrameworkServlet.configureAndRefreshWebApplicationContext(FrameworkServlet.java:647)
    org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:598)
    org.springframework.web.servlet.FrameworkServlet.createWebApplicationContext(FrameworkServlet.java:661)
    org.springframework.web.servlet.FrameworkServlet.initWebApplicationContext(FrameworkServlet.java:517)
    org.springframework.web.servlet.FrameworkServlet.initServletBean(FrameworkServlet.java:458)
    org.springframework.web.servlet.HttpServletBean.init(HttpServletBean.java:138)
    javax.servlet.GenericServlet.init(GenericServlet.java:212)
    org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:555)
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
    org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:852)
    org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
    org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
    java.lang.Thread.run(Thread.java:662)
</pre></p><p><b>root cause</b> <pre>java.lang.IllegalStateException: Ambiguous mapping found. Cannot map 'sdtm-controller' bean method 
public java.util.List&lt;java.lang.String&gt; com.sas.hls.clc.clinicalstandards.sdtm.SDTM_Controller.getVersions()
to {[/getVersions],methods=[GET],params=[],headers=[],consumes=[],produces=[],custom=[]}: There is already 'SDTM_Controller' bean method
public java.util.List&lt;java.lang.String&gt; com.sas.hls.clc.clinicalstandards.sdtm.SDTM_Controller.getVersions() mapped.

我的控制器类只有一个名为 getVersions() 的方法。当我在控制器上使用 AutoWired 并且没有明确地将任何 bean 连接在一起时,我的应用程序运行良好。但后来我转而定义一些 bean,以便我可以连接到项目中其他人编写的 bean。我开始收到重复的 bean 异常,所以我注释掉了 @Autowired 注释。为什么我会得到这个。我部署的环境中是否还有自动装配的残余物???

@Controller
public class SDTM_Controller {
    private SDTM_Service service;

//  @Autowired
    public SDTM_Controller(SDTM_Service service){
        this.service = service;
    }

    public SDTM_Controller(){

    }

    public void setSDTM_Service(SDTM_Service service){
        this.service = service;
    }

    // URL: sdtm/getVersions

    @RequestMapping(value="/getVersions", method=RequestMethod.GET)
    public @ResponseBody List<String> getVersions(){
        return service.getVersions();
    }

我的 web.xml 包括以下内容:

<servlet>
    <servlet-name>sdtm</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>/WEB-INF/sdtm-servlet.xml</param-value>
    </init-param>
</servlet>
<servlet-mapping>
    <servlet-name>sdtm</servlet-name>
    <url-pattern>/sdtm/*</url-pattern>
</servlet-mapping>

我有一个名为 sdtm-servlet.xml 的文件,其中包括以下内容:

    <context:component-scan base-package="com.sas.hls.clc.clinicalstandards.sdtm" />    
<mvc:annotation-driven/>

    <bean id="sdtm-controller" class="com.sas.hls.clc.clinicalstandards.sdtm.SDTM_Controller" >    
            <property name="SDTM_Service" ref="SDTM_Service" />  
    </bean>

最后,我有一个定义服务的 services-config.xml 文件。

   <bean id="sdtmService" class="com.sas.hls.clc.clinicalstandards.sdtm.SDTM_ServiceImpl" >
        <property name="clinicalStandardsInterface" ref="clinicalStandardsInterface" />
   </bean>

【问题讨论】:

  • 不要把它放在 XML 中。您现在拥有同一个 bean 的 2 个实例。
  • 删除控制器的“@Bean”解决了我的问题:我正在将预先存在的 web 应用程序升级到新版本的 Spring Boot。我不得不删除控制器的“@Bean”,因为“@RestController”注释已经在创建它了! “@Bean”注释只是导致spring尝试再次映射它。

标签: spring spring-mvc mapping


【解决方案1】:

您的 &lt;mvc:annotation-driven/&gt; 标签告诉 spring 遍历您的类以查找注释并创建带注释的类的实例。您的 &lt;bean id="sdtm-controller .../&gt; 还会创建您的控制器的实例。所以创建的第二个会给出错误,因为已经创建了一个。正如 M. Deinum 所指出的,您只需要其中一个,并且由于您使用的是注解,因此只需删除 bean 配置即可。

【讨论】:

  • 我遇到了完全相同的问题(或非常相似)。我需要在 XML 中包含 bean 的原因是可以初始化 bean。在上面的示例中,有一个 用于初始化 SDTM_Service 值。在我的例子中,我使用的是构造函数注入,所以我有 而不是 。我看到了 XML 中的 bean 定义和 之间的冲突。那么......使用注解(@Controller)有没有办法注入其他 bean(例如 SDTM_Service),无论是在 XML 中定义还是注解(例如 @Service)?
  • 您是否考虑过自动装配构造函数并使用限定符作为 xml 初始化的替代方法? stackoverflow.com/questions/2153657/…
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-02-24
  • 1970-01-01
  • 2015-07-09
  • 2020-06-17
相关资源
最近更新 更多