为什么使用dozer
分析多层架构的J2EE系统,经常存在JavaBean直接的拷贝。比如我们在DAO层,通过DO取得业务层需要的数据,将这些数据传递给Service层的VO。DO与VO就存在典型的值拷贝。典型的解决方案就是手动拷贝,弊端很明显,代码中充斥大量Set和Get方法,真正的业务被埋藏值与值的拷贝之中。另一种方案就是使用BeanUtil,但是BeanUtil不够很好的灵活性,有时候还不得不手动拷贝。Dozer可以灵活的对对象进行转换,且使用简单。
Spring和Dozer整合
- pom依赖引入
<dependency>
<groupId>net.sf.dozer</groupId>
<artifactId>dozer</artifactId>
<version>5.5.1</version>
</dependency>
<dependency>
<groupId>net.sf.dozer</groupId>
<artifactId>dozer-spring</artifactId>
<version>5.5.1</version>
</dependency>
- Spring配置文件
<bean id="mapper" class="org.dozer.spring.DozerBeanMapperFactoryBean">
<property name="mappingFiles">
<list>
<!-- 把Dozer映射文件引入 -->
<value>classpath*:dozer-mapping.xml</value>
</list>
</property>
</bean>
以上的配置使得spring-mvc重复扫描了Service类,而spring如果要使事务生效,就需要cglib为Service生成代理子类,在spring.xml中已经生成了代理类,而在spring-mvc.xml中,又重新扫描了一遍,使得原先cglib生成的代理子类失效,从而事务拦截也失效。所以我们应该设置spring-mvc.xml,使其不扫描@Service和@Component,spring.xml不扫描@Controller。