gpt4 book ai didi

java - EclipseLink 和 Spring 3 Web MVC : how should I integrate both technologies?

转载 作者:行者123 更新时间:2023-11-30 11:44:34 24 4
gpt4 key购买 nike

我目前正在学习 EclipseLinkSpring 3.0 MVC:

  • 我使用 EclipseLink 编写了一个简单的独立应用程序:它使用 META-INF/persistence.xml 文件并从 mysql 数据库读取和写入数据。

  • 我还在 apache tomcat 下使用 Spring3 MVC 编写了一个简单的“HelloWorld”应用程序。它基于以下教程:http://www.mkyong.com/spring-mvc/spring-3-rest-hello-world-example

现在,我应该如何将这两种技术联系起来?据我了解 http://static.springsource.org/spring/docs/3.0.0.M3/spring-framework-reference/html/ch14s06.html我需要创建一个 LocalContainerEntityManagerFactoryBean:

 <bean id="myEmf" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="dataSource" ref="someDataSource"/>
<property name="loadTimeWeaver">
<bean class="org.springframework.instrument.classloading.InstrumentationLoadTimeWeaver"/>
</property>
</bean>

但是“someDataSource”是什么?我应该使用另一个库吗 http://commons.apache.org/dbcp/ ?那我应该用 eclipselink 做什么?

一旦配置了 JPA,我应该如何从我的 spring Controller 访问它?

谢谢

最佳答案

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 namespace ,以及

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。

一般来说,您可能需要在 Controller 和存储库 (DAO) 之间有一个服务层。原因是 Controller 应该只专注于处理请求和响应。任何业务逻辑都应该通过业务对象等在不同的层中完成。服务层充当 Web 层和存储库层之间的中介。这不仅分离了关注点,而且还使事情变得更加可单元测试,这是任何 Spring 应用程序的重要组成部分(至少它应该是!)。

至于如何连接,尝试将这个 bean 也插入到您的 Context 中:

<context:component-scan base-package="xx.yy..." />

其中 xx 和 yy 是您的包名称,这将告诉 Spring 扫描您的包以查找“组件”或@Controller 对象、@Service 和@Repository(还有一些其他的,但这些是需要了解的主要内容关于)。通过向 Spring 提供此信息,您可以将 @Autowire bean(依赖注入(inject))到其他 bean 中。

例如:

@Service
public class SomeServiceImpl implements SomeService
{
private SomeRepository someRepository;

@Autowired
public void setSomeRepository(SomeRepository someRepository)
{
this.someRepository = someRepository;
}
...
}

这会将存储库注入(inject)到服务中,允许您访问该存储库方法。

另一个设计技巧,总是在 Spring 中为接口(interface)编程。由于在开发早期,您可能想要实现 Hibernate 存储库,但 DBA 可能对此嗤之以鼻,并需要使用直接 SQL 的 JDBC 存储库,因此在涉及存储库时尤其如此。这样,您只需要使用 JDBC 方法而不是 Hibernate 来实现存储库,注入(inject) JDBC 存储库而不是 Hibernate,就大功告成了。

希望这能让您入门!

关于java - EclipseLink 和 Spring 3 Web MVC : how should I integrate both technologies?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10734696/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com