dozer简单实例入门

转自 http://www.blogjava.net/killme2008/archive/2007/02/06/98250.html


呵呵,在《develope J2EE without EJB》中,DTO被狠很地批判了一把,rod说这完全是反模式。可实际项目当中,我们还是不得不在使用。VO,PO,一牵扯到概念总是多么复杂。。。把一个PO从头传到尾??从页面到数据库,一捅到底?NO,NO,万一你要显示给用户的是几个PO的结合怎么办?万一我们只是需要某几个属性组合在一起显示怎么办?一捅到底的策略是多么丑陋,而且你完全把你的数据库设计模型暴露给用户。所以我们需要一些map工具来转换,在这方面,过去我只知道有个 BeanUtils,不够灵活,而今天,接触了下dozer,啊,跟spring一样的理念!灵活多变,你想怎么映射,想怎么换都可以。看看它支持的转换类型:

• Primitive to Primitive Wrapper
• Primitive to Custom Wrapper
• Primitive Wrapper to Primitive Wrapper

• Primitive to Primitive
• Complex Type to Complex Type
• String to Primitive
• String to Primitive Wrapper
• String to Complex Type if the Complex Type contains a String constructor
• Each of these can be mapped to one another: java.util.Date, java.sql.Date, java.sql.Time,
java.sql.Timestamp, java.util.Calendar, java.util.GregorianCalendar
• String to any of the supported Date/Calendar Objects if an explicit date format mapping attribute is
specified.
• Objects containing a toString() method that produces a long representing time in (ms) to any
supported Date/Calendar object.

几乎我们能想到的,它都提供了方法来做到。而且dozer可以很容易地跟spring集成。下面举个简单例子:

定义一个Book对象:

package com.denny_blue.dozerdemo;
public class Book {
 private String name;
 private String author;
 
 
 public Book(){
  
 } 
 public void setAuthor(String author) {
  this.author = author;
 }

 public String getAuthor() {
  return (this.author);
 }
 public void setName(String name){
  this.name=name;
 } 
 public String getName(){
  return this.name;
 }
}
简单的,我们要实例化一个对象,然后clone此对象,注意,是clone!

package com.denny_blue.dozerdemo;
import net.sf.dozer.util.mapping.DozerBeanMapper;
import java.util.List;
import java.util.ArrayList;


public class MyFirstDozerDemo {
 public static void main(String args[]){
  Book book1=new Book();
  book1.setAuthor("dennis");
  book1.setName("dozer demo");
  DozerBeanMapper mapper=new DozerBeanMapper();
  Book book2=new Book();
  mapper.map(book1,book2);
  book2=(Book)mapper.map(book1,com.denny_blue.dozerdemo.Book.class);
  System.out.println("book2's name:"+book2.getName());
     }

OK,如此简单,我们把book1的属性完全复制给了book2,两者现在是完全独立的对象。可如果仅仅是这样,我们用BeanUtils不是也很容易办到? book2=(Book)BeanUtils.cloneBean(book1);可如果我要把book1映射给一个完全不同的类的对象怎么办?而且他们的属性名也不相同,怎么办?比如,一个CookBook类:

package com.denny_blue.dozerdemo;
public class CookBook {
 private String bookName;
 private String author;


 public CookBook(){}
 public String getBookName() {
  return (this.bookName);
 }

 public void setBookName(String bookName) {
  this.bookName = bookName;
 }

 public String getAuthor() {
  return (this.author);
 }

 public void setAuthor(String author) {
  this.author = author;
 }


}
它的bookName属性与Book的name属性名不一样,我们该如何复制?dozer通过xml文件的配置来灵活地达到这个目的。我们配置一个dozerBeanMapping.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mappings PUBLIC "-//DOZER//DTD MAPPINGS//EN"
"http://dozer.sourceforge.net/dtd/dozerbeanmapping.dtd">
<mappings>
<configuration>
<stop-on-errors>false</stop-on-errors>
<date-format>MM/dd/yyyy HH:mm</date-format>
<wildcard>true</wildcard>
</configuration>
<mapping>
<class-a>com.denny_blue.dozerdemo.Book</class-a>
<class-b>com.denny_blue.dozerdemo.CookBook</class-b>
<field>
<a>name</a>
<b>bookName</b>
</field>
<field>
<a>author</a>
<b>author</b>
</field>
</mapping>
</mappings>

如上所示,<class-a>指定所要复制的源对象,<class-b>复制的目标对象,<a>源对象的属性名, <b>目标对象的属性名。wildcard默认为true,在此时默认对所有属性进行map,如果为false,则只对在xml文件中配置的属性进行map。此时的demo 看起来像这样:

package com.denny_blue.dozerdemo;
import net.sf.dozer.util.mapping.DozerBeanMapper;
import java.util.List;
import java.util.ArrayList;


public class MyFirstDozerDemo {
 public static void main(String args[]){
  Book book1=new Book();
  book1.setAuthor("dennis");
  book1.setName("dozer demo");
  DozerBeanMapper mapper=new DozerBeanMapper();
  book2=(Book)mapper.map(book1,com.denny_blue.dozerdemo.Book.class);
  CookBook cookBook=new CookBook();
  List myMappingFiles = new ArrayList();
  myMappingFiles.add("dozerBeanMapping.xml");
  mapper.setMappingFiles(myMappingFiles);
  cookBook=(CookBook)mapper.map(book1,CookBook.class);
  System.out.println("cookBook's name:"+   cookBook.getBookName()+"     cookBook's author:"+
                      cookBook.getAuthor());
 }
}

通过mapper.setMappingFiles()设置映射文件,可以添加多个配置文件,也可以把所有的映射写在一个配置文件里面。  更多复杂例子请见它自带的doc。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单Dozer入门案例,假设我们有两个Java类:Person和PersonDTO,它们之间的属性有一些不同,我们需要进行对象之间的转换。 首先,我们需要引入Dozer的依赖,如果使用Maven,可以在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>com.github.dozermapper</groupId> <artifactId>dozer-core</artifactId> <version>5.5.1</version> </dependency> ``` 接下来,我们需要定义一个Dozer映射文件,将Person对象的属性映射到PersonDTO对象的属性。在src/main/resources目录下创建一个名为"dozer_mapping.xml"的文件,内容如下: ```xml <?xml version="1.0" encoding="UTF-8"?> <mappings xmlns="http://dozermapper.github.io/schema/bean-mapping" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://dozermapper.github.io/schema/bean-mapping http://dozermapper.github.io/schema/bean-mapping.xsd"> <mapping> <class-a>com.example.Person</class-a> <class-b>com.example.PersonDTO</class-b> <field> <a>name</a> <b>fullName</b> </field> <field> <a>age</a> <b>age</b> </field> </mapping> </mappings> ``` 这个映射文件定义了Person和PersonDTO之间的映射关系,将Person对象的"name"属性映射到PersonDTO对象的"fullName"属性,将Person对象的"age"属性映射到PersonDTO对象的"age"属性。 接下来,我们可以编写测试代码,使用Dozer来进行对象之间的转换。在src/test/java目录下创建一个名为"MapperTest.java"的文件,内容如下: ```java package com.example; import org.dozer.DozerBeanMapper; import org.dozer.Mapper; import org.junit.Test; import static org.junit.Assert.assertEquals; public class MapperTest { @Test public void testMapping() { Mapper mapper = new DozerBeanMapper(); Person person = new Person("John", 30); PersonDTO personDTO = mapper.map(person, PersonDTO.class); assertEquals("John", personDTO.getFullName()); assertEquals(30, personDTO.getAge()); } } ``` 这个测试代码创建了一个DozerBeanMapper对象,然后使用它来将Person对象转换为PersonDTO对象,并且验证了转换结果是否正确。 最后,我们可以运行测试代码,检查结果是否符合预期。如果一切正常,那么我们已经成功地使用Dozer进行了对象之间的转换。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值