描述:当实体类中出现两个存放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