xml报文格式如下,想要获取标签中的PAGE_URL属性的值:
<?xml version="1.0" encoding="UTF-8"?>
<root>
<DocInfo>
<APP_CODE>CLP</APP_CODE>
<APP_NAME>车险理赔</APP_NAME>
<BUSI_NO>G20202400000000000005</BUSI_NO>
</DocInfo>
<PAGES>
<PAGE PAGE_ID="48f9d267-abb3-43a1-a4f9-dfdbc7227107" DOC_TYPE="CL009" DOC_NAME="影像信息" PAGE_URL="48f9d267-abb3-43a1-a4f9-dfdbc7227107.jpg" PAGE_NAME="222.png" UP_USER="0000000000" UP_ORG="三公司" UP_TIME="2020-02-21 15:53:51"/>
</PAGES>
</root>
第一步:先创建一下工具类
import java.io.InputStream;
import java.io.FileInputStream;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
public class XMLParse {
public static void main(String[] args) throws Exception {
//1-获取XML-IO流
InputStream xmlInputStream = getXmlInputStream("H:\\图片下载\\20200220/G20202400000000000005"+"\\busi.xml");
//2-解析XML-IO流 ,获取Document 对象,以及Document对象 的根节点
Element rootElement = getRootElementFromIs(xmlInputStream);
//3~5-从根元素解析得到元素
parseElementFromRoot(rootElement);
}
//1-获取XML-IO流
public static InputStream getXmlInputStream(String xmlPath){
InputStream inputStream = null;
try {
//1-把要解析的 XML 文档转化为输入流,以便 DOM 解析器解析它
inputStream= new FileInputStream(xmlPath);
} catch (Exception e) {
e.printStackTrace();
}
return inputStream;
}
//2-解析XML-IO流 ,获取Document 对象,以及Document对象 的根节点
public static Element getRootElementFromIs(InputStream inputStream) throws Exception {
if(inputStream == null){
return null;
}
/*
* javax.xml.parsers 包中的DocumentBuilderFactory用于创建DOM模式的解析器对象 ,
* DocumentBuilderFactory是一个抽象工厂类,它不能直接实例化,但该类提供了一个newInstance方法 ,
* 这个方法会根据本地平台默认安装的解析器,自动创建一个工厂的对象并返回。
*/
//2-调用 DocumentBuilderFactory.newInstance() 方法得到创建 DOM 解析器的工厂
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
//3-调用工厂对象的 newDocumentBuilder方法得到 DOM 解析器对象。
DocumentBuilder docBuilder = factory.newDocumentBuilder();
//4-调用 DOM 解析器对象的 parse() 方法解析 XML 文档,得到代表整个文档的 Document 对象,进行可以利用DOM特性对整个XML文档进行操作了。
Document doc = docBuilder.parse(inputStream);
//5-得到 XML 文档的根节点
Element root =doc.getDocumentElement();
//6-关闭流
if(inputStream != null){
inputStream.close();
}
return root;
}
//3-从根元素解析得到元素
public static void parseElementFromRoot(Element root) {
NodeList nl = root.getChildNodes();
for (int i = 0; i < nl.getLength(); i++) {
Node node = nl.item(i);
if (node instanceof Element) {
Element ele = (Element) node;
//4-从元素解析得到属性值
//getDataFromElement(ele);
//5-从元素解析特定子元素并解析(以PAGE_URL为例)
getCertainElementFromParentElement(ele);
}
}
}
//4-从元素解析得到属性值
public static String getDataFromElement(Element ele) {
String PAGEURL = ele.getAttribute("PAGE_URL");//根据属性名称读取属性值
/*System.out.println("name == " + name);
String className = ele.getAttribute("class");
System.out.println("className == " + className);*/
return PAGEURL;
}
//5-从元素解析特定子元素并解析(以PAGE_URL为例)
public static void getCertainElementFromParentElement(Element ele) {
NodeList propertyEleList = ele.getElementsByTagName("PAGE");//根据标签名称获取标签元素列表
for (int i = 0; i < propertyEleList.getLength(); i++) {
Node node = propertyEleList.item(i);
if (node instanceof Element) {
Element propertyEle = (Element) node;
String PAGE_URL = propertyEle.getAttribute("PAGE_URL");
System.out.println("PAGE_URL: name == " + PAGE_URL);
/* String value = propertyEle.getAttribute("value");
System.out.println("propertyEle: value == " + value);*/
}
}
执行工具类中的main方法: 其中的getCertainElementFromParentElement方法,就可返回PAGE_URL属性的值。
wl_sqfn
发布了44 篇原创文章 · 获赞 6 · 访问量 2万+
私信
关注