我正在尝试解析XML文件以获取特定标记的属性。下面是我的XML文件 -
<?xml version="1.0" encoding="UTF-8"?>
<app hash='nv' name='Tech' package='1.0' version='13' filesize='200' create_date='01-03-1987' upate_date='07-09-2013' >
<url>
<name>RJ</name>
<score>10</score>
</url>
<url>
<name>ABC</name>
<score>20</score>
</url>
</app>
我正在尝试从上面的XML文件中获取hash,name,package,version,filesize,create_date,update_date值。
下面是我的代码,我试图解析上面的XML文件,但我不确定如何从app
标记中获取上述必需属性?
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
try {
InputStream is = request.getInputStream();
Document doc = DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(is);
doc.getDocumentElement().normalize();
System.out.println("root of xml file" + doc.getDocumentElement().getNodeName());
//get hash, name, package value from the app tag in the XML file
} catch (Exception e) {
System.out.println(e);
}
有人可以帮我解决这个问题吗?
答案 0 :(得分:2)
您可以使用Jsoup,这是一个很棒的Java库,可用于处理任何基于XML的文档。
在您的情况下,您可以使用“app”标记获取标记并解析其属性,如下所示:
String result = getStringFromInputStream(is);
Document doc = Jsoup.parse(result, "", Parser.xmlParser());
Element e = doc.getElementsByTag("app").first();
System.out.println(e.attr("hash"));
System.out.println(e.attr("name"));
//etc...
为了将InputStream转换为String,您可以使用MyKong's method:
private static String getStringFromInputStream(InputStream is) {
BufferedReader br = null;
StringBuilder sb = new StringBuilder();
String line;
try {
br = new BufferedReader(new InputStreamReader(is));
while ((line = br.readLine()) != null) {
sb.append(line);
}
} catch (IOException e) {
e.printStackTrace();
} finally {
if (br != null) {
try {
br.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return sb.toString();
}
祝你好运!