以XML文件格式的内容保存:
String ext = metaFileName.substring(metaFileName.lastIndexOf("."));
logger.debug("文件后缀名:" + ext);
if(!".xml".equalsIgnoreCase(ext)) {
addActionError("文件类型错误,只能是XML格式的文件。");
} else {
logger.debug("元数据文件:{}", meta.getAbsolutePath());
logger.debug("元数据文件存在:{}", meta.exists());
SAXReader sax = new SAXReader();
Document doc;
try {
doc = sax.read(meta);
getModel().setFileContent(doc.asXML());
super.save();
} catch (DocumentException e) {
e.printStackTrace();
}
}
开始读取XML文件的时候用的是流的方式,影响文件编码格式(以后做事要多动脑子,多试。。。。)
读取XML后,根据xml标签说明对应文件,解析XML成文本内容。
public String queryMetadataInfo() {
Metadata mdata = getManager().getMatadataInfo(getModel().getType());
if (mdata != null) {
XMLWriter outFile = null;
try {
logger.debug("元数据文件内容:{}", mdata.getFileContent());
Document outerdoc = DocumentHelper.parseText(mdata.getFileContent());
String folderPath = getServletContext().getRealPath("/metafile/");
File folder = new File(folderPath);
if (!folder.exists()) {
folder.mkdirs();
}
outFile = new XMLWriter(new FileOutputStream(folderPath + File.separator + mdata.getMetaSet()+ ".xml"));
outFile.write(outerdoc);
Document doc = readDoc(folderPath + File.separator + mdata.getMetaSet()+ ".xml");
Element root = doc.getRootElement();
//读取元数据文件对应的节点信息
Map infoMap = getMetaFileInfo(folderPath + File.separator + "config.xml");
//遍历元数据文件所有的子节点
viewAllElement(root);
String mContent = mdata.getFileContent();
for (Node node : metaList) {
if (StringUtils.isBlank(node.getText())) {
mContent = mContent.replace("</"+node.getName()+">", "<br/>").replace("<"+node.getName()+">",
"<b>" + infoMap.get(node.getName()).toString() + "<br/>" + "</b>").replace(" ", " ");
} else {
mContent = mContent.replace("</"+node.getName()+">", "<br/>").replace("<"+node.getName()+">",
"<b>" + infoMap.get(node.getName()).toString() + ": " + "</b>").replace(" ", " ");
}
}
getResponse().setCharacterEncoding("UTF-8");
getResponse().setContentType("text/html");
render(getResponse(), "<font size='2'>"+mContent+"</font>", "text/html");
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if (outFile != null) {
outFile.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
} else {
render(getResponse(), "暂无数据", "text/html");
}
return null;
}
/**
* 读取元数据文件对应的节点信息
* @param filePath 文件
*/
@SuppressWarnings("unchecked")
private Map getMetaFileInfo(String filePath) {
Document document = readDoc(filePath);
List nodeList = document.selectNodes("//item");
Iterator iter = nodeList.iterator();
Map fileInfoMap = new HashMap();
while(iter.hasNext()){
Element element=(Element)iter.next();
Iterator itemNameIter=element.elementIterator("itemName");
Iterator aliasIter=element.elementIterator("itemAlias1");
Element itemNameElement = null;
Element aliasElement = null;
while(itemNameIter.hasNext()){
itemNameElement=(Element)itemNameIter.next();
}
while(aliasIter.hasNext()){
aliasElement=(Element)aliasIter.next();
}
//logger.info(itemNameElement.getText() + " : " + aliasElement.getText());
fileInfoMap.put(itemNameElement.getText(), aliasElement.getText());
}
return fileInfoMap;
}
/**
* 取得document对象
* @param filename 文件名
*/
private Document readDoc(String filename) {
SAXReader reader = new SAXReader();
try {
return reader.read(new FileInputStream(new File(filename)));
} catch (DocumentException e) {
e.printStackTrace();
throw new ApplicationException(e.getMessage());
} catch (Exception e) {
e.printStackTrace();
throw new ApplicationException(e.getMessage());
}
}
/**
* 遍历所有节点
* @param element
*/
@SuppressWarnings("unchecked")
public void viewAllElement(Element element) {
for ( int i = 0, size = element.nodeCount(); i < size; i++ ) {
Node node = element.node(i);
if ( node instanceof Element ) {
viewAllElement( (Element) node );
//logger.info("节点名称:" + node.getName() + " 节点内容:" + node.getText());
metaList.add(node);
}
}
}
多想,多试,使用多种方法实现。。。
分享到:
相关推荐
在“dom4j解析xml文件(增删改查)”这个主题中,我们将深入探讨如何使用DOM4J来实现XML文档的四种基本操作:增加元素、删除元素、更新元素内容以及查询元素。 首先,让我们了解DOM4J的基本用法。在解析XML文件时,...
5. **事件驱动解析(SAX)**:除了传统的DOM解析外,DOM4J还支持SAX解析器,这种解析方式适用于处理大型XML文件,因为它不需要一次性加载整个文档到内存。 6. **Namespace支持**:DOM4J提供了对XML命名空间的全面...
### DOM4J解析XML详解 #### 一、DOM4J简介与特性 DOM4J是一个由dom4j.org开发的开源XML解析包,专为Java平台设计,它不仅支持DOM、SAX和JAXP标准,还巧妙地融入了Java集合框架,使其成为Java开发者在处理XML数据时...
在本示例中,我们将深入探讨如何使用DOM4J解析XML文件,以`CacheInit.java`作为我们的核心代码示例,并参考`emailTemplateConfig.xml`作为实际操作的对象。 首先,让我们了解XML(eXtensible Markup Language)。...
"以及解析xml文档所用的pdf文档说明"则表明还有一个PDF文档,可能详细介绍了如何使用dom4j来解析XML文件,包括各种方法、类和接口的使用示例。 **dom4j解析XML文档知识点:** 1. **dom4j简介**:dom4j是一个开放...
本篇文章将深入探讨如何使用DOM4J来解析XML文件,以及通过示例代码来展示其基本操作。 首先,我们需要理解DOM4J的工作原理。DOM4J采用的是DOM(Document Object Model)模型,它将整个XML文档加载到内存中形成一棵...
以下是如何使用DOM4j解析XML: 1. 引入DOM4j库(如:dom4j-1.6.1.jar)。 2. 创建DocumentFactory实例。 3. 使用DocumentFactory的read()方法读取XML文件,得到Document对象。 4. 使用Document对象提供的方法(如...
在使用DOM4j解析XML文件时,首先需要导入DOM4j的相关包,如`SAXReader`用于读取XML文件,`Document`表示整个XML文档,`Element`表示XML文档中的元素,以及`Attribute`表示元素的属性。以下是一个使用DOM4j解析XML...
DOM4J是一个强大的Java库,专门用于解析XML文档。它提供了简单易用的API,使得开发者可以更加方便地处理XML数据。DOM4J的核心优势在于它的面向接口编程设计,这使得它能够在不同的解析机制间灵活切换,如DOM、SAX和...
通过这种方式,我们可以利用DOM4J解析XML文件,同时借助Java反射机制将解析结果动态地映射到自定义的Java类中。这在处理XML数据时提供了很大的灵活性,尤其在需要将XML数据与业务对象关联时,反射机制显得尤为重要。
1、xml文档解析 2、 dom4j解析xml 3、实现xml文件解析 xml字符串解析 xml MAP键值对解析 4、实现xml写入与生成文件
在这个实例中,我们将深入探讨如何使用DOM4J解析XML文件,并通过`Dom4jTest1.java`这个示例程序来理解其工作原理。 首先,我们需要了解XML(Extensible Markup Language)是一种标记语言,常用于存储和传输数据。...
以下是一个DOM4J解析XML的简单示例: ```java import org.dom4j.Document; import org.dom4j.DocumentHelper; import org.dom4j.Element; public class Dom4jExample { public static void main(String[] args) {...
Java DOM4J解析XML是一种常见的处理XML文档的技术,它提供了灵活且高效的API,使得开发者能够方便地读取、写入、修改以及操作XML文件。DOM4J是Java中一个非常强大的XML处理库,它结合了DOM、SAX和JDOM的优点,同时也...
要开始解析XML文件,首先需要导入DOM4J的相关包: ```java import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.io.SAXReader; ``` 接下来,我们将创建...
**DOM4J解析XML** DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活、高效且功能丰富的API,使得XML的读取、创建、修改和查询变得简单易行。DOM4J的主要特点包括对XPath的支持、事件驱动的解析、以及与...
**DOM4J解析XML实例详解** 在Java编程中,处理XML文档是一项常见的任务。DOM4J是一个非常流行的、强大的Java XML API,它提供了灵活且高效的方式来解析、创建、修改XML文档。本文将深入探讨如何使用DOM4J进行XML...
### DOM4J解析XML知识点详解 #### 一、DOM4J简介 DOM4J是一个Java库,用于处理XML文档。它的设计目标是为了提供一个简单、易于使用的API来处理XML文件,同时保持性能上的优势。与Java标准库中的DOM实现相比,DOM4J...
DOM4J是一个强大的Java库,专门用于处理XML文档。它提供了灵活且高效的API,使得XML的解析、创建、修改和查询变得简单。DOM4J的名字来源于DOM(Document Object Model)和Java的结合,但它的设计理念比标准DOM更先进...