3

私は一般的にautowireとDIに問題があるので、誰かが私が何日も立ち往生している原因を助けてくれることを願っています。

これはコードです:

@Service
public class TicketsController implements Controller {
  private TicketManager ticketManager;

  @Autowired
public void setTicketManager(TicketManager ticketManager) {
    this.ticketManager = ticketManager;
}
...
}


@Service
public class SimpleTicketManager implements TicketManager {
  private TicketsDao ticketsDao;

@Autowired
public void setTicketsDao(TicketsDao ticketsDao) {
    this.ticketsDao = ticketsDao;
}
 ...
}

@Repository
public class JdbcTicketDao implements TicketsDao  {
  private DataSource dataSource;
  @Autowired
  public void setDataSource(DataSource dataSource)  {
    this.dataSource=dataSource;
      this.jdbcTemplate = new JdbcTemplate(this.dataSource);   
     }
...
}

public final class AppContext {
ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");
BeanFactory factory = context;
TicketsController ticketsController = (TicketsController) factory.getBean("ticketsController");
}
...
}

私のbeans.xmlには次のものがあります。

<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClass" value="com.mysql.jdbc.Driver"/>
    <property name="url" value="jdbc:mysql://localhost:3306/mytckdb"/>
    <property name="username" value="user"/>
    <property name="password" value="pass"/>
</bean>
<context:component-scan base-package="bp.dao" />
<context:component-scan base-package="bp.mvc" />
<context:component-scan base-package="bp.svc" />
<context:component-scan base-package="bp.view" />

これは機能せず、次のようになります。

Error creating bean with name 'jdbcTicketDao': Injection of autowired dependencies failed
... nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: 
    No matching bean of type [javax.sql.DataSource] found for dependency.` 

誰かがこれを手伝ってくれますか?私は何が間違っているのですか?自動配線は、dataSourceの挿入時に失敗する次のステップまですべて機能しているようです。

編集:私はコードで遊んでいて、setDataSource()の前に@Autowireを忘れていましたが、そこにあるはずです。

4

5 に答える 5

2

配線構成が足りない可能性があります。試してみてください

<context:annotation-config/>

于 2012-10-08T18:32:36.757 に答える
1

これは、Bean インスタンスの作成順序によるものです。dataSource インスタンスが作成される前に、DAO がインスタンス化されています。

前にデータ ソース Bean 定義を保持する

別の方法は、別のxmlでdataSource定義を定義し、その前にインポートすることです

于 2015-06-20T09:45:04.440 に答える
0

変化する

<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClass" value="com.mysql.jdbc.Driver"/>
    <property name="url" value="jdbc:mysql://localhost:3306/mytckdb"/>
    <property name="username" value="user"/>
    <property name="password" value="pass"/>
</bean>

<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
    <property name="url" value="jdbc:mysql://localhost:3306/mytckdb"/>
    <property name="username" value="user"/>
    <property name="password" value="pass"/>
</bean>

プロパティはdriverClassName、ではなくと呼ばれdriverClassます。

context:component-scanまた、複数の要素は必要ありません変更できます

<context:component-scan base-package="bp.dao" />
<context:component-scan base-package="bp.mvc" />
<context:component-scan base-package="bp.svc" />
<context:component-scan base-package="bp.view" />

<context:component-scan base-package="bp.dao,bp.mvc,bp.svc,bp.view" />
于 2012-10-09T08:07:25.557 に答える
0

使用しているようですが、で導入されたSpring 2.0と思います。たぶん、春のxml-configと春の依存関係をに更新しますか?context:component-scanSpring 2.52.5

于 2012-10-08T18:42:42.437 に答える
0

試してくださいorg.apache.commons.dbcp.BasicDataSource

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
        destroy-method="close" p:driverClassName="com.mysql.jdbc.Driver"
        p:url="jdbc:mysql://127.0.0.1:3306/mytckdb?autoReconnect=true"
        p:username="user" p:password="pass" />

私はJPAを使用しているので、通常はEntityManagerFactoryを作成してそれを使用することを好みます

    <bean id="entityManagerFactory"
            class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
            <property name="dataSource" ref="dataSource" />
            <property name="persistenceUnitName" value="PU" />
            <property name="jpaVendorAdapter">
                <bean id="jpaAdapter"
                    class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
                    <property name="database" value="${database}" />
                    <property name="showSql" value="true" />
                    <property name="generateDdl" value="false" />
                </bean>
            </property>
        </bean>

<bean id="txManager" class="org.springframework.orm.jpa.JpaTransactionManager">
        <property name="entityManagerFactory" ref="entityManagerFactory" />
    </bean>

    <tx:annotation-driven transaction-manager="txManager" />
于 2012-10-08T17:45:48.347 に答える