您的位置:首页 > 编程语言 > Java开发

Java se对解析操作xml的支持及简单应用

2012-10-29 09:12 288 查看
       在《数据迁移》中迁移的一个核心处理是解析并更新本地xml文件,而这种操作简单利用java API即可完成。在 javax.xml.parsers包中提供了处理xml文件的类,使用它们我们可以将xml文件读入内存; javax.xml.transform包中提供了一些转换工具,我们可以将一种源树形转化为目标树形结果,例如我们可以将dom型源转化为InputStream型,这样可以将内存中的xml文件存储在硬盘上;而在org.w3c.dom中提供了JAVA处理XML的DOM接口,可以帮助我们获取相应结点,创建结点,处理节点属性等等操作。

      利用javax.xml.parsers包中,将xml文件的inputstream解析成Document,代码如下:
//所用包:
import org.w3c.dom.Document;
import javax.xml.parsers.DocumentBuilder;
importjavax.xml.parsers.DocumentBuilderFactory;

//解析成document
DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder docBuilder = docBuilderFactory.newDocumentBuilder();
Document doc = docBuilder.parse(inputStream);

//创建document
DocumentBuilderFactory dbf =DocumentBuilderFactory.newInstance();
DocumentBuilder db =dbf.newDocumentBuilder();
Document doc = db.newDocument();
Node rootNode = doc.createElement(“rootNodeName”);
doc.appendChild(rootNode);       上文内容可以帮助我们从inputstream中解析出xml文件成DOM,或者自己创建Document,以供后续操纵xml。而在《数据迁移》中除了要能够读取本地xml文件,还要能将修改后的xml文件写入指定位置,从而导入内容库中,而这个过程则可以利用javax.xml.transform等包实现。
        在javax.xml.transform包中提供Transformer和TransformerFactory类。其中Transformer类提供了方法transform(Source xmlSource, Result outputTarget) ,它能够帮助我们将xml源以一种形式。
在javax.xml.transform包中定义了source和result的接口,而在javax.xml.transform.dom、javax.xml.transform.stream、javax.xml.transform.sax和javax.xml.transform.stax中分别做了source和result的不同实现。在《数据迁移》中需要将内存中的dom转移到Inputstream形式,进而能够存储到硬盘中,其实现过程如下所示:
import javax.xml.transform.Result;
import javax.xml.transform.Source;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;

import org.w3c.dom.Document;

public InputStream toInputStream(Document doc) {
InputStream inputStream = null;
StringWriter stringWriter = null;
try {
TransformerFactory tranFactory = TransformerFactory.newInstance();
Transformer transformer = tranFactory.newTransformer();
Source src = new DOMSource(doc);
stringWriter = new StringWriter();
Result dest = new StreamResult(stringWriter);
transformer.transform(src, dest);

StringBuffer sb = stringWriter.getBuffer();
if (stringWriter != null){
stringWriter.close();
}
inputStream = new ByteArrayInputStream(sb.toString().getBytes("UTF-8"));
} catch (Exception e) {
logger.error("", e);
try {
if (stringWriter != null)
stringWriter.close();
if (inputStream != null)
inputStream.close();
} catch (IOException e1) {
logger.error("", e);
}
}
return inputStream;
}
       上文说明了如何将硬盘xml文件读入内存,以及如何写入硬盘,其都借助了Inputstream,而在xml操作中需要对xml结点及结点属性进行读取或设置。如下代码分别进行展示。
 import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

//获取指定结点的相应结点名称的结点值
public String getNodeValue(Node parentNode, String nodeName) {
String s = "";
if (parentNode.getNodeType() == Node.ELEMENT_NODE) {

Element rootElement = (Element) parentNode;

NodeList childList = rootElement.getElementsByTagName(nodeName);
Element childElement = (Element) childList.item(0);
if (childElement != null) {
NodeList textFNList = childElement.getChildNodes();
if (textFNList != null) {
Node temp = (Node) textFNList.item(0);
if (temp != null) {
s = temp.getNodeValue();
if (s != null)
s = s.trim();
}
}
}
}
return s;
}

//获取指定结点的子节点
public NodeList getNodeList(Node node) {
NodeList nodeList = node.getChildNodes();
return nodeList;
}
//获取指定结点名称的结点
public Node getNodeByTagName(Node parentNode, String tagName) {
Element rootElement = (Element) parentNode;
NodeList nodeList = rootElement.getElementsByTagName(tagName);
if (nodeList.getLength() > 0)
return nodeList.item(0);
else
return null;
}

//获取指定结点名称的结点列表
public NodeList getNodeListByTagName(Node parentNode, String tagName) {
Element rootElement = (Element) parentNode;
NodeList nodeList = rootElement.getElementsByTagName(tagName);
return nodeList;
}

//获取指定属性值
public String getNodeAttribute(Node node, String attName) {
Element elem = (Element) node;
return elem.getAttribute(attName);
}

//创建结点并设置属性
public Node createNode(String tagName, Map<String, String> attributeMap) {
Element element = doc.createElement(tagName);
if (attributeMap != null && !attributeMap.isEmpty()) {
Iterator<Entry<String, String>> it = attributeMap.entrySet()
.iterator();
while (it.hasNext()) {
Entry<String, String> entry = it.next();
element.setAttribute(entry.getKey(), entry.getValue());
}
}
return element;
}      本文简单介绍了java se中操作xml的包和类,并在此基础上提供了解析和转化inputstream以及操作结点和结点属性的方法,为日后简单操作xml而不仅是依赖第三方工具包做了示范。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: