描述:当实体类中出现两个存放String类型的List集合时,使用xstream的alias方法无法分别转换其为对应的名称。
<?xml version="1.0" encoding="UTF-8"?> <info> <rogIDs> <orgID>020120214</orgID> <orgID>020120215</orgID> </rogIDs> <roleIDs> <roleID>020120216</roleID> <roleID>020120217</roleID> </roleIDs> </info>
此时需要使用自定义的Converter实现list元素的分别命名
public class OrgIDConverter implements Converter {
@SuppressWarnings("unchecked")
public void marshal(Object value, HierarchicalStreamWriter writer,
MarshallingContext arg2) {
// 将Object向下转型,因为有canConvert方法的判断,所以不用instanceOf判断
List<String> list = (List<String>) value;
for (String subval : list) {
// 该名称orgIDs集合的String类型元素名称
writer.startNode("orgID");
writer.setValue(subval);
writer.endNode();
}
}
public Object unmarshal(HierarchicalStreamReader reader,
UnmarshallingContext context) {
// 声明List集合,用于接受xml的orgID元素并存储
List<String> list = new ArrayList<String>();
while (reader.hasMoreChildren()) {
reader.moveDown();
String key = reader.getNodeName();
String value = null;
// 这一步可以省略,直接使用else内容,if的内容是orgID下还有层元素,嵌套遍历
if (reader.hasMoreChildren()) {
value = (String)unmarshal(reader, context);
} else {
value = reader.getValue();
}
list.add(value);
reader.moveUp();
}
return list;
}
public boolean canConvert(Class type) {
// 判断传入class的类型,注意:一定要使用声明类(List不能通过)
return type.equals(ArrayList.class);
}
}
roleIDs的内容和上面的java代码类似,将元素名称orgID修改为roleID即可。
PS:1.动态判断传入的List名称,从而使用一个类完成不同List(orgIDs、roleIDs)的标签转换;
2.更加方便的解决方案。
以上两个问题,如果大家有方案和思路,谢谢留言。
以上问题已经找到优化方案,详见:http://winnie825.iteye.com/admin/blogs/1439933