2012-04-12 1 views
2

Я пытаюсь создать приложение, которое обращается к базе данных SQL Server, используя Spring, Maven и Hibernate. Когда я пытаюсь запустить приложение IM получаю следующее сообщение об ошибке:Неверное определение бина с именем 'dataSource', определенным в ресурсе пути к курсу [spring/database/DataSource.xml]

Exception in thread "main" org.springframework.beans.factory.BeanDefinitionStoreException: Invalid bean definition with name 'dataSource' defined in class path resource [spring/database/DataSource.xml]: Could not resolve placeholder 'jdbc.driverClassName' 

Вот мои классы

DataSoucre.xml

<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-2.5.xsd"> 

<bean 
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> 
<property name="location"> 
    <value>/properties/database.properties</value> 
</property> 
</bean> 

<bean id="dataSource" 
    class="org.springframework.jdbc.datasource.DriverManagerDataSource"> 
<property name="driverClassName" value="${jdbc.driverClassName}" /> 
<property name="url" value="${jdbc.url}" /> 
<property name="username" value="${jdbc.username}" /> 
<property name="password" value="${jdbc.password}" /> 
</bean> 

</beans> 

Hibernate.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-2.5.xsd"> 

<!-- Hibernate session factory --> 
<bean id="sessionFactory" 
class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"> 
<property name="dataSource"> 
    <ref bean="dataSource"/> 
</property> 

<property name="hibernateProperties"> 
    <props> 
    <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop> 
    <prop key="hibernate.show_sql">true</prop> 
    </props> 
</property> 

<property name="annotatedClasses"> 
<list> 
    <value>com.fexco.helloworld.web.model.Customer</value> 
</list> 
</property> 

</bean> 
</beans> 

и базы данных .properties

database.driverClassName=net.sourceforge.jtds.jdbc.Driver 
database.url=jdbc:jtds:sqlserver://localhost:1433;databaseName=Customer 
database.username=***** 
database.password=***** 

(Я заблокировал имя пользователя и пароль только для здесь), у меня также есть BeanLocation.xml, но мне не нужно его публиковать.

Кто-нибудь знает, как решить эту проблему, сводя ее с ума! Благодаря

+0

Я думаю, что проблема находится в вашей собственности.. файл. У вас есть в свойствах корневой папки classpath и внутри базы данных.properties? – chalimartines

ответ

11

Вместо ${jdbc.driverClassName} в вашем XML, используйте ${database.driverClassName}, то есть название имущества, используемого в файле database.properties.

+0

отлично, это трюк ... я бы пометил его, но недостаточно, чтобы сделать это еще:/thanks – newSpringer

0

Прежде всего, вам нужно убедиться, что корневое расположение файлов конфигурации доступно в пути к классам, а затем добавьте относительный путь вашего файла свойств, например. : путь к классам недвижимость/database.properties

В моем случае, additinal вопрос был Additonal «"»присутствует по ошибке, которая была ведущей к этой ошибке Надеются, что это помогает

Смежные вопросы

 Смежные вопросы