假设我有以下类
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功能请求的解决方案?
答案 0 :(得分:1)
您可以随时编写自己的CustomConverter。
为什么Dozer无法像你期望的那样处理它,这是有道理的,因为在运行时它没有关于List foos
的类型信息,并且无法保证列表中的每个Object
实际上都是Foo
。
答案 1 :(得分: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的字符串字段并将其作为String返回。
我认为您可以发布功能请求以支持映射到基元
<mapping>
<class-a>Foo</class-a>
<class-b>String</class-b>
<field>
<a>string</a>
</field>
</mapping>
进入推土机GitHub
答案 2 :(得分: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>