【问题标题】:Parsing a XML file with JDOM2 under AndroidAndroid下用JDOM2解析XML文件
【发布时间】:2013-06-24 18:07:59
【问题描述】:

我在使用库 JDOM2(准确地说是 2.0.5)在 Android 应用程序中解析 XML 文件时遇到问题。

在 Java 项目中,它工作正常,但在 Android 应用程序项目中,我收到以下消息:“无法打开 http://jeancdc.perso.sfr.fr/fichierXML.xml

这是我的 XMLReader 类:

package fr.jcdc.exemple.jdom;

import java.io.IOException;
import java.util.List;

import org.jdom2.Document;
import org.jdom2.Element;
import org.jdom2.JDOMException;
import org.jdom2.input.SAXBuilder;

import android.util.Log;

public class XMLReader {

    public XMLReader() {
        super();
    }

    public void loading() {

        try {

            SAXBuilder builder = new SAXBuilder();

            Document document = (Document) builder.build("http://jeancdc.perso.sfr.fr/fichierXML.xml");

            Element rootNode = document.getRootElement();
            List<Element> charactersList = rootNode.getChildren("personnage");

            for (int i = 0; i < charactersList.size(); i++) {

               Element node = (Element) charactersList.get(i);

               Log.d("tag", node.getChildText("prenom") + " " + node.getChildText("nom"));      
            }

        }
        catch (IOException ioex) {
            Log.d("ioex", ioex.getMessage());
        }
        catch (JDOMException jdomex) {
            Log.d("jdomex", jdomex.getMessage());
        }   
    }
}

还有我的主要课程:

package fr.jcdc.exemple.jdom;

import android.os.Bundle;
import android.app.Activity;

public class MainActivity extends Activity {

    private XMLReader xmlReader = new XMLReader();

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        xmlReader.loading();
    }
}

这是我在日志中得到的异常跟踪的一部分:

06-24 22:58:39.794: D/ioex(18560): Couldn't open http://jeancdc.perso.sfr.fr/fichierXML.xml
06-24 22:58:39.794: W/System.err(18560): java.io.IOException: Couldn't open http://jeancdc.perso.sfr.fr/fichierXML.xml
06-24 22:58:39.864: W/System.err(18560):    at org.apache.harmony.xml.ExpatParser.openUrl(ExpatParser.java:755)
06-24 22:58:39.864: W/System.err(18560):    at org.apache.harmony.xml.ExpatReader.parse(ExpatReader.java:292)
06-24 22:58:39.864: W/System.err(18560):    at org.jdom2.input.sax.SAXBuilderEngine.build(SAXBuilderEngine.java:217)
06-24 22:58:39.864: W/System.err(18560):    at org.jdom2.input.sax.SAXBuilderEngine.build(SAXBuilderEngine.java:277)
06-24 22:58:39.864: W/System.err(18560):    at org.jdom2.input.SAXBuilder.build(SAXBuilder.java:1141)
.....
06-24 22:58:39.864: W/System.err(18560): Caused by: android.os.NetworkOnMainThreadException
06-24 22:58:39.872: W/System.err(18560):    at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1117)
06-24 22:58:39.872: W/System.err(18560):    at java.net.InetAddress.lookupHostByName(InetAddress.java:385)
06-24 22:58:39.872: W/System.err(18560):    at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
06-24 22:58:39.880: W/System.err(18560):    ... 20 more

【问题讨论】:

  • 你的应用有网络权限吗?
  • 我在 AndroidManifest.xml 中添加了这一行: 我需要添加其他权限吗?
  • 如何提供有关错误消息的更多详细信息。有原因吗?
  • 这个日志文件有帮助吗? log.txt

标签: android xml parsing jdom jdom-2


【解决方案1】:

最后的评论很有帮助。查看NetworkOnMainThreadException 的谷歌搜索结果

您不再被允许从应用程序的主线程访问网络。创建带有回调的子线程以加载 XML

【讨论】:

  • 好的,为了验证,我通过更改 AndroidManifest.xml 中的以下行将目标更改为版本 9:android:targetSdkVersion="9" 并且它可以工作。所以现在,我必须实现另一个线程才能与更高的 API 兼容。谢谢!
【解决方案2】:

尝试传递 URL 而不是传递字符串。

java.net.URL temp;
try {
     temp = new java.net.URL("http://jeancdc.perso.sfr.fr/fichierXML.xml");
} catch (java.net.MalformedURLException e) {
     temp = null;
}
Document document = (Document) builder.build(temp);

【讨论】:

  • 已经尝试过了,不幸的是,它并没有解决问题。我在上面加入了一个日志文件。
猜你喜欢
  • 2016-07-29
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-01-10
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多