在java中从url读取xml中的数据

时间:2014-05-14 15:26:08

标签: java xml url

我需要能够使用此xml从欧元中取出USD转换: http://www.ecb.europa.eu/stats/eurofxref/eurofxref-daily.xml

如果我手动下载xml并解析我需要的数据,我已经得到了它的工作,但我不确定如何直接从网址抓取它。

谢谢

2 个答案:

答案 0 :(得分:1)

如果我理解得很清楚,您无法直接从网址获取xml内容,是吗?

如果是这样,这可能会对您有所帮助。

// the SAX way:
XMLReader myReader = XMLReaderFactory.createXMLReader();
myReader.setContentHandler(handler);
myReader.parse(new InputSource(new URL(url).openStream()));

// or if you prefer DOM:
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
Document doc = db.parse(new URL(url).openStream());

它适用于服务或独立上下文,但如果您尝试从WEB层访问XML,则可以考虑采用AJAX方法。

答案 1 :(得分:0)

不能比这更容易:

package com.danielmarreco;

import org.w3c.dom.Document;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

import org.w3c.dom.Element;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import java.io.InputStream;
import java.net.URL;

public class Main {

    public static void main(String[] args) {
        try {
            InputStream is = new URL("http://www.ecb.europa.eu/stats/eurofxref/eurofxref-daily.xml").openStream();
            DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
            DocumentBuilder db = dbf.newDocumentBuilder();
            Document doc = db.parse(is);

            NodeList nodeList = doc.getElementsByTagName("Cube");

            for (int i = 0; i < nodeList.getLength(); i ++) {
                Node node = nodeList.item(i);
                if (node.getNodeType() == Node.ELEMENT_NODE) {
                    Element element = (Element) node;
                    if(element.getAttribute("currency").equals("BRL")) 
                        System.out.println("1 EUR = " + element.getAttribute("rate") + " BRL");
                }
            }
        }
        catch (Exception e)        {
            e.printStackTrace();
        }
    }
}