6

假设我有以下课程

public class Baz {
  private List<Foo> foos = new ArrayList<Foo>();
}

public class Foo {
  private String string;
}

public class Target {
  private List<String> fooStrings = new ArrayList<String>();
}

有没有我可以使用的映射,给定一个 Baz,将它映射到目标类并获取 Baz 中 foo 中包含的字符串列表?以下映射不起作用

<mapping>
  <class-a>Baz</class-a>
  <class-b>Target</class-b>
  <field>
    <a>foos.string</a>
    <b>fooStrings</b>
  </field>
</mapping>

因为 string 不是 foos 的属性(它是 List 类型)。我原以为 Dozer 会足够聪明,如果它在深度映射中遇到一个集合,并且目标也是一个集合,那么它能够将深度属性名称分成两个并遍历集合以获取子部分来自集合成员的深度映射。显然不是。除了提出 Dozer 的功能请求之外,是否有解决方案?

4

3 回答 3

1

我想,你可以写这样一个映射

<mapping>
  <class-a>Baz</class-a>
  <class-b>Target</class-b>
  <field>
    <a>foos</a>
    <b>fooStrings</b>
  </field>
</mapping>

<custom-converters> 
  <converter type="CustomFooConverter">
    <class-a>
      Foo
    </class-a>
    <class-b>
      String
    </class-b>
  </converter>
</custom-converters>

并实现 CustomFooConverter 以获取 foo 的字符串字段并将其作为字符串返回。

我认为您可以发布一个功能请求以支持映射到原语

<mapping>
  <class-a>Foo</class-a>
  <class-b>String</class-b>
  <field>
    <a>string</a>
  </field>
</mapping>

进入推土机GitHub

于 2013-01-09T14:47:15.407 回答
1

您始终可以编写自己的CustomConverter

为什么 Dozer 无法按照您的预期处理这个问题是有道理的,因为在运行时它没有关于 the 的类型信息List foos并且不能保证Object列表中的每个实际上都是一个Foo.

于 2010-02-04T01:41:29.253 回答
0

我认为您可以在没有自定义转换器的情况下做到这一点。

重写 Foo 类的 toString() 方法,如下所示:

@Override
public String toString(){
return this.getString(); //assuming string property has a getter method. if not,write this.string

现在是以下映射:

<mapping>
<class-a>fully qualified name of Baz(with package name)</class-a>
<class-b>same for Target</class-b>
<field>
   <a>foos</a>
   <b>fooStrings</b>
   <a-hint>foo</a-hint>
   <b-hint>java.lang.String</b-hint>
</field>
</mapping>
于 2012-06-02T10:48:52.690 回答