разобрать XML и преобразовать в коллекцию

<inputs>
  <MAT_NO>123</MAT_NO>
  <MAT_NO>323</MAT_NO>
  <MAT_NO>4223</MAT_NO>
  <FOO_BAR>122</FOO_BAR>
  <FOO_BAR>125</FOO_BAR>
</inputs>

Мне нужно проанализировать XML, указанный выше. После синтаксического анализа я хочу, чтобы значения были в Map > со значениями ключей, соответствующими дочерним узлам - MAT_NO, FOO_BAR и values ​​- значения дочерних узлов -123, 323 и т. д.

Ниже мой снимок. Есть ли лучший способ сделать это ??

public class UserInputsXmlParser extends DefaultHandler {

 private final SaveSubscriptionValues subscriptionValues = null;
 private String nodeValue = "";
 private final String inputKey = "";
 private final List<String> valuesList = null;
 private Map<String, List<String>> userInputs;

 public Map<String, List<String>> parse(final String strXML) {
  try {
   final SAXParserFactory parserFactory = SAXParserFactory
     .newInstance();
   final SAXParser saxParser = parserFactory.newSAXParser();
   saxParser.parse(new InputSource(new StringReader(strXML)), this);
   return userInputs;
  } catch (final SAXException e) {
   e.printStackTrace();
   throw new MyException("", e);
  } catch (final IOException e) {
   e.printStackTrace();
   throw new MyException("", e);
  } catch (final ParserConfigurationException e) {
   e.printStackTrace();
   throw new MyException("", e);
  } catch (final Exception e) {
   e.printStackTrace();
   throw new MyException("", e);
  }
 }

 @Override
 public void startElement(final String uri, final String localName,
   final String qName, final Attributes attributes)
   throws SAXException {
  nodeValue = "";

  if ("inputs".equalsIgnoreCase(qName)) {
   userInputs = MyUtil.getNewHashMap();
   return;
  }

 }

 @Override
 public void characters(final char[] ch, final int start, final int length)
   throws SAXException {
  if (!MyUtil.isEmpty(nodeValue)) {
   nodeValue += new String(ch, start, length);
  } else {
   nodeValue = new String(ch, start, length);
  }
 }

 @Override
 public void endElement(final String uri, final String localName,
   final String qName) throws SAXException {
  if (!"inputs".equalsIgnoreCase(qName)) {
   storeUserInputs(qName, nodeValue);
  }

 }

 /**
  * @param qName
  * @param nodeValue2
  */
 private void storeUserInputs(final String qName, final String nodeValue2) {
  if (nodeValue2 == null || nodeValue2.trim().equals("")) { return; }
  final String trimmedValue = nodeValue2.trim();
  final List<String> values = userInputs.get(qName);
  if (values != null) {
   values.add(trimmedValue);
  } else {
   final List<String> valueList = new ArrayList<String>();
   valueList.add(trimmedValue);
   userInputs.put(qName, valueList);
  }
 }

 public static void main(final String[] args) {
  final String sample = "<inputs>" + "<MAT_NO>154400-0000</MAT_NO>"
    + "<MAT_NO>  </MAT_NO>" + "<MAT_NO>154400-0002</MAT_NO>"
    + "<PAT_NO>123</PAT_NO><PAT_NO>1111</PAT_NO></inputs>";
  System.out.println(new UserInputsXmlParser().parse(sample));
 }

}

ОБНОВЛЕНИЕ: Потомки узлов являются динамическими. Я буду знать только корневой узел.

1
задан jai 11 October 2010 в 16:52
поделиться