XML解析成Map

1 篇文章 0 订阅
1 篇文章 0 订阅
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;

/**
 * 将XML解析成MAP
 * @author Joe
 * @version $Id: XMLInToMap.java, v 0.1 2014年12月18日 下午8:25:21 Joe Exp $
 */
public class XMLToMap {
    
    
    public Map<String, String> getXML(String requestXml){
        Map<String, String> map = new HashMap<String, String>();
        // 将字符串转为XML
        Document doc;
        try {
            doc = DocumentHelper.parseText(requestXml);
            // 获取根节点
            Element rootElm = doc.getRootElement();//从root根节点获取请求报文
            XMLToMap xmlIntoMap = new XMLToMap();
            map = xmlIntoMap.parseXML(rootElm, new HashMap<String, String>());
        } catch (DocumentException e) {
            e.printStackTrace();
        }
       
        
        return map;
    }
    /**
     * 将xml解析成map键值对
     * <功能详细描述>
     * @param ele 需要解析的xml对象
     * @param map 入参为空,用于内部迭代循环使用
     * @return
     * @see [类、类#方法、类#成员]
     */
    private  Map<String, String> parseXML(Element ele, Map<String, String> map)
    {
        
        for (Iterator<?> i = ele.elementIterator(); i.hasNext();)
        {
            Element node = (Element)i.next();
            //System.out.println("parseXML node name:" + node.getName());
            if (node.attributes() != null && node.attributes().size() > 0)
            {
                for (Iterator<?> j = node.attributeIterator(); j.hasNext();)
                {
                    Attribute item = (Attribute)j.next();
                    
                    map.put(item.getName(), item.getValue());
                }
            }
            if (node.getText().length() > 0)
            {
                map.put(node.getName(), node.getText());
            }
            if (node.elementIterator().hasNext())
            {
                parseXML(node, map);
            }
        }
        return map;
    }
}

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值