someDataSource 只是另一个 bean,例如:
<bean id="someDataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<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>
在这里,我还使用属性替换属性,这是由以下 bean 指定的:
<context:property-placeholder location="classpath:properties/runtime.properties" />
由于上下文位于不同的 xml 命名空间下,因此添加:
xmlns:context="http://www.springframework.org/schema/context"
到您的 XML 命名空间,以及
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd
到 bean xml 文档中的 schemaLocation 字符串。
classpath:properties/runtime.properties
此属性文件可以在标准 Maven 设置中的以下位置找到:
src/main/resources/properties/runtime.properties
在这个 runtime.properties 文件中,您需要为每个具有占位符的属性定义值(即 jdbc.driverClassName、jdbc.url 等)。这方面的一个例子是:
jdbc.driverClassName=com.mysql.jdbc.Driver
如果您使用 MySQL 作为数据库。
一般来说,您可能需要在控制器和存储库 (DAO) 之间建立一个服务层。原因是控制器应该只专注于处理请求和响应。任何业务逻辑都应该通过业务对象等在不同的层中完成。服务层充当 Web 层和存储库层之间的中介。这不仅分离了关注点,而且使事情变得更加可单元测试,这是任何 Spring 应用程序的重要组成部分(至少它应该是!)。
至于如何连接,请尝试将此 bean 插入到您的 Context 中:
<context:component-scan base-package="xx.yy..." />
其中 xx 和 yy 是您的包名称,这将告诉 Spring 扫描您的包中的“组件”或 @Controller 对象、@Service 和 @Repository(还有一些其他的,但这些是要了解的主要内容)。使用提供给 Spring 的这些信息,您可以将 @Autowire bean(依赖注入)注入其他 bean。
例如:
@Service
public class SomeServiceImpl implements SomeService
{
private SomeRepository someRepository;
@Autowired
public void setSomeRepository(SomeRepository someRepository)
{
this.someRepository = someRepository;
}
...
}
这会将存储库注入服务,允许您访问该存储库方法。
另一个设计技巧,总是在 Spring 中为接口编程。对于存储库来说尤其如此,因为在开发的早期,您可能想要实现一个 Hibernate 存储库,但是 DBA 可能会对此嗤之以鼻,并需要使用直接 SQL 的 JDBC 存储库。这样,您只需要使用 JDBC 方法而不是 Hibernate 来实现 Repository,注入 JDBC 存储库而不是 Hibernate,就完成了。
希望这能让你开始!