2017-06-15 51 views
0

在SpringSource論壇上嘗試並等待答案的幾天後,我會在這裏嘗試一下。 運行我的應用程序會導致此異常:爲什麼我得到一個無資格bean錯誤?

org.springframework.beans.factory.UnsatisfiedDependencyException: 
    Error creating bean with name 'loginDAOImpl': 
    Unsatisfied dependency expressed through method 'setDataSource' parameter 0: 
    No qualifying bean of type [org.apache.tomcat.dbcp.dbcp.BasicDataSource] 
    found for dependency [org.apache.tomcat.dbcp.dbcp.BasicDataSource]: 
    expected at least 1 bean which qualifies as autowire candidate for this dependency. 
Dependency annotations: {}; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type [org.apache.tomcat.dbcp.dbcp.BasicDataSource] found for dependency [org.apache.tomcat.dbcp.dbcp.BasicDataSource]: expected at least 1 bean which qualifies as autowire candidate for this dependency. Dependency annotations: {} 
at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredMethodElement.inject(AutowiredAnnotationBeanPostProcessor.java:648) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE] 
at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:88) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE] 
at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessPropertyValues(AutowiredAnnotationBeanPostProcessor.java:349) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE] 
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1214) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE] 
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:543) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE] 
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:482) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE] 
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:306) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE] 
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE] 
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:302) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE] 
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:197) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE] 
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:776) ~[spring-beans-4.3.2.RELEASE.jar:4.3.2.RELEASE] 
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:866) ~[spring-context-4.3.8.RELEASE.jar:4.3.8.RELEASE] 
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:542) ~[spring-context-4.3.8.RELEASE.jar:4.3.8.RELEASE] 
at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:122) ~[spring-boot-1.5.3.RELEASE.jar:1.5.3.RELEASE] 
at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:737) [spring-boot-1.5.3.RELEASE.jar:1.5.3.RELEASE] 
at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:370) [spring-boot-1.5.3.RELEASE.jar:1.5.3.RELEASE] 
at org.springframework.boot.SpringApplication.run(SpringApplication.java:314) [spring-boot-1.5.3.RELEASE.jar:1.5.3.RELEASE] 
at org.springframework.boot.SpringApplication.run(SpringApplication.java:1162) [spring-boot-1.5.3.RELEASE.jar:1.5.3.RELEASE] 
at org.springframework.boot.SpringApplication.run(SpringApplication.java:1151) [spring-boot-1.5.3.RELEASE.jar:1.5.3.RELEASE] 
at com.example.demo.DemoApplication.main(DemoApplication.java:10) 

下面是相關的代碼

應用程序上下文:

<?xml version="1.0" encoding="UTF-8"?> 
<beans xmlns="http://www.springframework.org/schema/beans" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xmlns:context="http://www.springframework.org/schema/context" 
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"> 


<context:annotation-config/> 

<!-- Scans within the base package of the application for @Component classes to configure as beans --> 
<context:component-scan base-package="com.example.demo" /> 

<bean id="dataSource" class="org.apache.tomcat.dbcp.dbcp.BasicDataSource" 
     destroy-method="close"> 
    <property name="driverClassName" value="com.mysql.jdbc.Driver"/> 
    <property name="url" value="jdbc:mysql://localhost/atata"/> 
    <property name="username" value="user"/> 
    <property name="password" value="pass"/> 
</bean> 

<context:property-placeholder location="jdbc.properties"/> 

類LoginDAOImpl:

@Repository 
public class LoginDAOImpl implements LoginDAO { 

private JdbcTemplate jdbcTemplateObject; 

@Autowired 
public void setDataSource(BasicDataSource dataSource) { 

    this.jdbcTemplateObject = new JdbcTemplate(dataSource); 
} 
... 
} 

主:

@SpringBootApplication 
public class DemoApplication { 

public static void main(String[] args) {   
    SpringApplication.run(DemoApplication.class, args); 
} 
} 
+0

你的xml配置幾乎沒用,你沒有'@ ImportResources',所以它什麼都不做。你也不需要它,因爲Spring Boot已經提供了你在xml中所做的一切。因此,第1步刪除它並將屬性從'jdbc.properties'移動到'application.properties'。重新啓動應用程序。 –

+0

謝謝。我認爲這應該有所幫助。 – user1902193

回答

0

一般來說, 包括與這樣的問題的更多細節。 具體來說, 什麼是LoginDAOImpl類包? 什麼是LoginDAOImpl類中的BasicDataSource類的導入?

起初猜測,我懷疑的BasicDataSource進口將org.apache.commons.dbcp.BasicDataSourceorg.apache.tomcat.dbcp.dbcp2.BasicDataSource

這是您的數據源bean定義使用類不同。

<bean id="dataSource" class="org.apache.tomcat.dbcp.dbcp.BasicDataSource" 
    destroy-method="close"> 

可能性二:

您正在使用的數據源bean配置的用戶名和密碼值的格式不正確。如果用戶和密碼是屬性值,則應使用${user}${pass}。像這樣:

<bean id="dataSource" class="org.apache.tomcat.dbcp.dbcp.BasicDataSource" 
    destroy-method="close"> 
    <property name="driverClassName" value="com.mysql.jdbc.Driver"/> 
    <property name="url" value="jdbc:mysql://localhost/atata"/> 
    <property name="username" value="${user}"/> 
    <property name="password" value="${pass}"/> 
</bean> 
+0

import org.apache.tomcat.dbcp.dbcp.BasicDataSource; 第二種可能性不是關於這個錯誤我想。無論如何,這不起作用。 有沒有其他的細節? – user1902193

+0

如果spring不能創建dataSource bean,它會記錄一個錯誤。檢查你的日誌中是否有彈簧錯誤也許設置彈簧日誌級別來調試。 – DwB