0

基本サービスを使用して応答を解析する単純なwebservice基本数学アプリを開発しました。XMLsax parserwebservice

私はすでにsaxパーサーを使用してXMLベースを解析していますwebserviceが、私の問題は、これを解析すると特定のtag. このため、私のコードは以下のとおりです。

private List < Object > callWebService() {
 try {
  SAXParserFactory factory = SAXParserFactory.newInstance();
  SAXParser parser = factory.newSAXParser();

  final List < Object > list = new ArrayList < Object > ();

  DefaultHandler handler = new DefaultHandler() {
   boolean language = false;
   boolean langid = false;
   boolean langname = false;
   boolean icon = false;

   public void startDocument() throws SAXException {
    list.clear();
   }

   public void endDocument() throws SAXException {}

   public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
    if (qName.equalsIgnoreCase("language")) {
     language = true;
     objLanguage = new Language();
     return;
    }

    if (qName.equalsIgnoreCase("langid")) {
     langid = true;
     return;
    }

    if (qName.equalsIgnoreCase("langname")) {
     langname = true;
     return;
    }
    if (qName.equalsIgnoreCase("icon")) {
     icon = true;
     return;
    }
   }

   public void endElement(String uri, String localName, String qName) throws SAXException {
    if (qName.equalsIgnoreCase("langid")) {
     langid = false;
     return;
    }

    if (qName.equalsIgnoreCase("langname")) {
     langname = false;
     return;
    }
    if (qName.equalsIgnoreCase("icon")) {
     icon = false;
     return;
    }

    if (qName.equalsIgnoreCase("language")) {
     if (langid == false && langname == false && icon == false) {
      language = false;
      list.add(objLanguage);
      return;
     }
    }
   }

   public void characters(char ch[], int start, int length) throws SAXException {
    String theString = new String(ch, start, length);

    if (langid == true) {
     objLanguage.setLangId(theString);
    } else if (langname == true) {
     objLanguage.setLangName(theString);
    } else if (icon == true) {
     objLanguage.setIconImage(genHelper.convertIconImageInByteBuffer(theString));
    }
   }
  };

  parser.parse("http://mathevaluate.com/webservice/langlist.php", handler);
  return list;
 } catch (Exception ex) {
  System.out.println("ERROR : " + ex.toString());
  return null;
 }
}

問題はlanguage、次のような非常に大きなデータ文字列を含む Name Tag です。

<langname>this is the part where  i can`t get the whole string of the tag so post this question</langname>

これを解析すると、このタグの適切な文字列値を取得できません。どうすれば取得できますか?

4

1 に答える 1

0

アポストロフィなどの特殊文字を応答に含めると、その特定のポイントでデータが壊れます。SAXパーサーの詳細については、こちらを参照してください:特殊文字を無視する

于 2012-10-04T05:12:02.520 に答える