SAXParser выдает org.apache.harmony.xml.ExpatParser$ParseException

Когда я пытаюсь проанализировать xml с помощью SAXParser в android. Последний '>' не будет работать. всегда показывать ошибку:

org.apache.harmony.xml.ExpatParser$ParseException: At line 15, column 12: not well-formed (invalid token)

Вот мой xml-файл:

<?xml version="1.0" encoding="utf-8"?> 
<magazines> 
<magazine id="176"> 
<publising>1</publising> 
<price>0</price> 
<paid_state>True</paid_state> 
<cover_img>http://172.23.5.222/files/images/pub/issue/image-20110517-10bcmaka9bklah8ph57o.jpg</cover_img> 
</magazine> 
<magazine id="175"> 
<publising>1</publising> 
<price>0</price> 
<paid_state>True</paid_state> 
<cover_img>http://172.23.5.222/files/images/pub/issue/image-20110517-9jqtrfo5lozztb7m5xlu.jpg</cover_img> 
</magazine> 
</magazines>

вот мой обработчик

public class BKXMLCoverContentHandler extends DefaultHandler  {

private String TAG = "BKXMLCoverContentHandler";

private TreeMap<Integer, Magazine> magazines;
private Magazine magazine;

private String tempString;

private static final String MAGAZINES = "magazines";
private static final String MAGAZINE = "magazine";
private static final String ID = "id";
private static final String PUBLISHING = "publising";
private static final String PRICE = "price";
private static final String PAID_STATE = "paid_state";
private static final String COVER_IMG = "cover_img";

public TreeMap<Integer, Magazine> getMagazines() {
    return magazines;
}


@Override
public void characters(char[] ch, int start, int length)
        throws SAXException {

    if (magazine != null) {
        String valueString = new String(ch, start, length);
        if (PUBLISHING.equals(tempString)) {
            Log.d(TAG, valueString);
            magazine.setPublishingStatus(valueString);
        } else if (PRICE.equals(tempString)) {
            Log.d(TAG, valueString);
            magazine.setPrice(valueString);
        } else if (PAID_STATE.equals(tempString)){
            Log.d(TAG, valueString);
            magazine.setPaidStatus(tempString);
        } else if (COVER_IMG.equals(tempString)){
            Log.d(TAG, valueString);
            magazine.setCoverUrl(valueString);
        } 
    } 
}

@Override
public void startElement(String uri, String localName, String name,
        Attributes attributes) throws SAXException {
    if (MAGAZINES.equals(localName)){
        Log.d(TAG, localName);
        magazines = new TreeMap<Integer, Magazine>();
    }

    if (MAGAZINE.equals(localName)) {

        magazine = new Magazine();
        Log.d(TAG, localName);
        magazine.setId(new Integer(attributes.getValue(ID)));
    } 
    tempString = localName;
}

@Override
public void endElement(String uri, String localName, String name)
        throws SAXException {
        if(MAGAZINE.equals(localName) && magazine != null){
            Log.d(TAG, localName);
            magazines.put(magazine.getId(), magazine);
            magazine = null;
        } else if(MAGAZINES.equals(localName)){
            Log.d(TAG, localName);
        }
        tempString = null;
}

}

Из кода вы можете видеть, что я зарегистрировал каждую строку. поэтому я получил вывод журнала:

D/BKXMLCoverContentHandler(  980): magazines
D/BKXMLCoverContentHandler(  980): magazine
D/BKXMLCoverContentHandler(  980): 1
D/BKXMLCoverContentHandler(  980): 0
D/BKXMLCoverContentHandler(  980): True
D/BKXMLCoverContentHandler(  980): http://172.23.5.222/files/images/pub/issue/image-20110517-10bcmaka9bklah8ph57o.jpg
D/BKXMLCoverContentHandler(  980): magazine
D/BKXMLCoverContentHandler(  980): magazine
D/BKXMLCoverContentHandler(  980): 1
D/BKXMLCoverContentHandler(  980): 0
D/BKXMLCoverContentHandler(  980): True
D/BKXMLCoverContentHandler(  980): http://172.23.5.222/files/images/pub/issue/image-20110517-9jqtrfo5lozztb7m5xlu.jpg
D/BKXMLCoverContentHandler(  980): magazine
D/BKXMLCoverContentHandler(  980): magazines

Может кто подскажет в чем дело?


person leona    schedule 17.05.2011    source источник
comment
ae Привет, как вы читаете этот xml-контент, я имею в виду, читаете ли вы его, вызывая любой URL-адрес, или вы просто анализируете локальный xml-файл на устройстве. пожалуйста подтвердите.   -  person Anup Rojekar    schedule 17.05.2011


Ответы (1)


Проблема была решена.

Я читаю xml с URL-адреса и записываю его на SD-карту своего устройства Android. Когда он пишет, я каждый раз использую чтение буфера 8 * 1024 байта. XML слишком короткий для 8 КБ, поэтому программа заполняет пустым файлом, используя 8 КБ. что вызывает проблему.

person leona    schedule 18.05.2011
comment
Ваша следующая проблема будет заключаться в том, что вы предполагаете, что все символьные данные между начальным и конечным тегами передаются в одном вызове символов, но в парсере sax это не обязательно верно, он может быть разбит на несколько вызовов. - person superfell; 18.05.2011