Синтаксический анализ типа XML - PullRequest
2 голосов
/ 14 февраля 2011

У меня есть веб-служба SOAP, которая возвращает XML в этом формате

<SOAP-ENV:Envelope SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
  <SOAP-ENV:Body>
    <ns1:GetResponse>
      <ret SOAP-ENC:arrayType="ns2:Map[2]" xsi:type="SOAP-ENC:Array">
         <item xsi:type="ns2:Map">
           <item>
              <key xsi:type="xsd:string">ProtocolId</key>
              <value xsi:type="xsd:string">1</value>
           </item>
           <item>
              <key xsi:type="xsd:string">Title</key>
              <value xsi:type="xsd:string">Some Title</value>
           </item>
           <item>
              <key xsi:type="xsd:string">Text</key>
              <value xsi:type="xsd:string"> Some Text </value>
           </item>
         </item> 
         <item xsi:type="ns2:Map">
           <item>
              <key xsi:type="xsd:string">ProtocolId</key>
              <value xsi:type="xsd:string">2</value>
           </item>
           <item>
              <key xsi:type="xsd:string">Title</key>
              <value xsi:type="xsd:string">Another Title</value>
           </item>
           <item>
              <key xsi:type="xsd:string">Text</key>
              <value xsi:type="xsd:string">Another Text </value>
           </item>
         </item> 
      </ret>
   </ns1:GetResponse>
 </SOAP-ENV:Body>

Как написать синтаксический анализатор для этого вида XML.Если у вас есть несколько примеров, это будет очень полезно.

Спасибо

Мукул

1 Ответ

2 голосов
/ 18 февраля 2011

Я заставил его работать с этим парсером -

public class XmlPullFeedParser extends BaseFeedParser {
public XmlPullFeedParser(String feedUrl) {
    super(feedUrl);
}

StringBuilder builder = new StringBuilder();
int whichItemFlag = 0;

Context thisContext;

DataBaseHelper myDB;

public void parse(InputStream is, Context context, String insertInto) {

    XmlPullParser parser = Xml.newPullParser();

    thisContext = context;
    myDB = new DataBaseHelper(thisContext);
    try {
        // auto-detect the encoding from the stream
        parser.setInput(is, "UTF-8");
        int eventType = parser.getEventType();
        boolean done = false;
        while (eventType != XmlPullParser.END_DOCUMENT && !done) {
            String name = null;
            String attr = null;
            switch (eventType) {
            case XmlPullParser.START_DOCUMENT:
                break;
            case XmlPullParser.START_TAG:
                name = parser.getName();
                attr = parser.getAttributeName(0);
                if (name.equalsIgnoreCase(ITEM)) {
                    if(attr!=null) {
                        builder.append("(");
                    }
                    whichItemFlag++;
                } else if (name.equalsIgnoreCase(VALUE)) {
                    builder.append("'"+parser.nextText().replaceAll("'", "&#39;")+"',");
                } 
                break;
            case XmlPullParser.END_TAG:
                name = parser.getName();
                if (name.equalsIgnoreCase(ITEM)) {
                    whichItemFlag--;
                    if(whichItemFlag==0) {
                        builder.delete(builder.length()-1, builder.length());
                        builder.append(")");
                        writeStringToDb(insertInto, builder.toString());
                        builder.delete(0, builder.length());
                    }
                } 
                break;
            }
            eventType = parser.next();
        } 
    } catch (Exception e) {
        e.printStackTrace();
//          throw new RuntimeException(e);
    } finally {
        myDB.close();
    }
}

private void writeStringToDb(String insertInto, String string) {
    SQLiteDatabase db = myDB.getWritableDatabase();
    String sql = insertInto + string;
    db.execSQL(sql);
    db.close();
}

Stringbuilder, который я использовал для создания строки из значений, возвращаемых XML, и использования этой строки непосредственно для записи в базу данных. Метод parse принимает входной поток, контекст приложения и строку, которая помогает мне построить оператор sql. С самого парсера я пишу напрямую в базу данных. Поскольку XML был очень большим (7 МБ), я должен был сделать это таким образом, иначе моему устройству Android не хватило бы памяти при создании более 1500 объектов.

...