import java.util.HashMap;
import java.util.Map;
/**
* 属性值类,描述页面动态表单域信息
*
*
*/
public class AttributeVO implements java.io.Serializable {
private static final long serialVersionUID = -8683922528577545017L;
public static enum Sort {
ASC, DESC
}
/**
* id
*/
private String id;
/**
* 字段名
*/
private String name;
/**
* 控件类型
*/
private String type;
/**
* 描述
*/
private String description;
/**
* 默认值
*/
private String value;
/**
* 码表Code
*/
private String codeId;
/**
* 正则
*/
private String regex;
/**
* 排序
*/
private String order;
/**
* Select下拉数据
*/
private Map<String, String> select = new HashMap<String, String>();
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getType() {
return type;
}
public void setType(String type) {
this.type = type;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public String getValue() {
return value;
}
public void setValue(String value) {
this.value = value;
}
public String getCodeId() {
return codeId;
}
public void setCodeId(String codeId) {
this.codeId = codeId;
}
public String getRegex() {
return regex;
}
public void setRegex(String regex) {
this.regex = regex;
}
public String getOrder() {
return order;
}
public void setOrder(String order) {
this.order = order;
}
public Map<String, String> getSelect() {
return select;
}
public void setSelect(Map<String, String> select) {
this.select = select;
}
}
import org.springframework.util.ResourceUtils;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathExpressionException;
import javax.xml.xpath.XPathFactory;
import java.io.*;
import java.util.*;
/**
* Date: 2010-4-4
* Time: 22:39:55
*/
public class AttributeVOXMLUtil {
public static Map<String, Map<String, AttributeVO>> attributeMap = new HashMap<String, Map<String, AttributeVO>>();
/**
* 解析XML
*
* @param xmlName
* @return
*
*/
private static Document getDocument(String xmlName) {
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = null;
try {
db = dbf.newDocumentBuilder();
} catch (ParserConfigurationException e) {
e.printStackTrace();
}
Document document = null;
try {
document = db.parse(new FileInputStream(ResourceUtils.getFile(ResourceUtils.CLASSPATH_URL_PREFIX + xmlName)));
} catch (IOException e) {
throw new XMLParserException("XML文件没有找到", e);
} catch (SAXException e) {
throw new XMLParserException("XML解析错误");
}
return document;
}
/**
* 根据Path返回节点列表
*
* @param document
* @param xPath
* @return
*
*/
private static NodeList getNodeList(Document document, String xPath) {
XPathFactory xpathFactory = XPathFactory.newInstance();
XPath xpath = xpathFactory.newXPath();
NodeList nodeList = null;
try {
nodeList = (NodeList) xpath.evaluate(xPath, document, XPathConstants.NODESET);
} catch (XPathExpressionException e) {
throw new XMLParserException("XPath错误");
}
return nodeList;
}
/**
* 根据Path返回单个节点
*
* @param document
* @param xPath
* @return
*
*/
private static Node getNode(Document document, String xPath) {
XPathFactory xpathFactory = XPathFactory.newInstance();
XPath xpath = xpathFactory.newXPath();
Node node = null;
try {
node = (Node) xpath.evaluate(xPath, document, XPathConstants.NODE);
} catch (XPathExpressionException e) {
throw new XMLParserException("XPath错误");
}
return node;
}
/**
* 根据id删除节点
*
* @param xmlName
* @param itemId
*/
private static void removeNode(String xmlName, String itemId) {
Document document = getDocument(xmlName);
Element root, attributeItem;
root = document.getDocumentElement();
attributeItem = (Element) getNode(document, "//attributeItem[@id='" + itemId + "']");
if (attributeItem != null) {
//删除一个节点
root.removeChild(attributeItem);
//写入到xml
writeXml(document, xmlName);
//删除缓存中的Map
attributeMap.remove(itemId);
}
}
/**
* 写入XML
*
* @param doc
* @param xmlName
*/
private static void writeXml(Document doc, String xmlName) {
OutputStream fileoutputStream = null;
try {
fileoutputStream = new FileOutputStream(ResourceUtils.getFile(ResourceUtils.CLASSPATH_URL_PREFIX + xmlName));
TransformerFactory factory = TransformerFactory.newInstance();
Transformer transformer = factory.newTransformer();
DOMSource source = new DOMSource(doc);
StreamResult result = new StreamResult(fileoutputStream);
transformer.transform(source, result);
} catch (FileNotFoundException e) {
throw new XMLParserException("没有找到XML文件", e);
} catch (TransformerConfigurationException e) {
throw new XMLParserException("文件写入错误", e);
} catch (TransformerException e) {
throw new XMLParserException("文件写入错误", e);
} finally {
if (fileoutputStream != null)
try {
fileoutputStream.close();
} catch (IOException e) {
throw new XMLParserException("文件流错误");
}
}
}
/**
* 返回信息
*
* @param xmlName
* @return
*
*/
public static Map<String, Map<String, AttributeVO>> queryParserXml(String xmlName) {
Document document = getDocument(xmlName);
document.normalize();
NodeList attributeItemList = getNodeList(document, "//attributeItem");
int itemLen = attributeItemList.getLength();
for (int i = 0; i < itemLen; i++) {
Element element = (Element) attributeItemList.item(i);
attributeMap.put(element.getAttribute("id"), getAttributeVOMap(document, "//attributeItem[@id='" + element.getAttribute("id") + "']/attribute"));
}
return attributeMap;
}
/**
* 封装AttributeItem信息
*
* @param document
* @param xPath
* @return
*
*/
private static Map<String, AttributeVO> getAttributeVOMap(Document document, String xPath) {
Map<String, AttributeVO> attributeVOMap = new HashMap<String, AttributeVO>();
NodeList attributeItemList = getNodeList(document, xPath);
int itemLen = attributeItemList.getLength();
for (int i = 0; i < itemLen; i++) {
Element element = (Element) attributeItemList.item(i);
attributeVOMap.put(element.getAttribute("name"), getAttributeVO(element, document, xPath + "[@id='" + element.getAttribute("id") + "']/select"));
}
return attributeVOMap;
}
/**
* 返回AttributeVO信息
*
* @param element
* @param document
* @param xPath
* @return
*
*/
private static AttributeVO getAttributeVO(Element element, Document document, String xPath) {
Map<String, String> selectMap = new HashMap<String, String>();
AttributeVO attributeVO = new AttributeVO();
NodeList attributeItemList = getNodeList(document, xPath);
int itemLen = attributeItemList.getLength();
for (int i = 0; i < itemLen; i++) {
Element selectElement = (Element) attributeItemList.item(i);
selectMap.put(selectElement.getAttribute("id"), selectElement.getAttribute("value"));
}
attributeVO.setId(element.getAttribute("id"));
attributeVO.setName(element.getAttribute("name"));
attributeVO.setType(element.getAttribute("type"));
attributeVO.setDescription(element.getAttribute("description"));
attributeVO.setValue(element.getAttribute("value"));
attributeVO.setCodeId(element.getAttribute("codeId"));
attributeVO.setRegex(element.getAttribute("regex"));
attributeVO.setOrder(element.getAttribute("order"));
attributeVO.setSelect(selectMap);
return attributeVO;
}
/**
* 返回AttributeVO列表
*
* @param itemId
* @return
*
* @see
*/
public static List<AttributeVO> queryAttribute(final String itemId) {
return queryAttribute(itemId, AttributeVO.Sort.ASC);
}
/**
* 返回AttributeVO列表
*
* @param itemId
* @param sort
* @return
*
* @see
*/
public static List<AttributeVO> queryAttribute(final String itemId, final AttributeVO.Sort sort) {
final List<AttributeVO> attributeVOList = new LinkedList<AttributeVO>();
final Map<String, AttributeVO> attributeVOMap = attributeMap.get(itemId);
if (attributeVOMap != null) {
final Iterator<String> iterName = attributeVOMap.keySet().iterator();
while (iterName.hasNext()) {
attributeVOList.add(attributeVOMap.get(iterName.next()));
}
//排序
Collections.sort(attributeVOList, new Comparator<AttributeVO>() {
@Override
public int compare(AttributeVO o1, AttributeVO o2) {
final AttributeVO AttributeVO1 = o1;
final AttributeVO AttributeVO2 = o2;
final Integer order1 = Integer.valueOf(AttributeVO1.getOrder());
final Integer order2 = Integer.valueOf(AttributeVO2.getOrder());
if (sort.equals(AttributeVO.Sort.ASC))
return order1 < order2 ? 0 : 1;
else
return order1 < order2 ? 1 : 0;
}
});
}
return attributeVOList;
}
/**
* 根据itemId删除元素
*
* @param itemId
*/
public static void removeItem(String itemId) {
removeNode("attribute.xml", itemId);
}
}
分享到:
相关推荐
DOMParser接口提供了解析XML字符串并创建DOM文档的方法,以便于开发者可以使用DOM API来查询、修改或操作XML数据。 以下是对"DOMParser解析XML"这一主题的详细说明: 1. **DOMParser的基本使用**: 使用DOMParser...
在"XML解析之DOM"这一主题中,我们将深入探讨DOM解析器如何工作,以及如何通过DOM API获取XML文件中的信息。DOM解析器将整个XML文档加载到内存中,形成一个节点树,每个元素、属性、文本等内容都对应一个节点。这种...
### Java DOM 解析 XML 在Java中,DOM(Document Object Model)是一种用于处理XML文档的标准接口。通过DOM,我们可以将整个XML文档加载到内存中,并对其进行读取、修改等操作。这种方式非常适合那些需要对XML文档...
**DOM4J——XML解析库详解** XML(eXtensible Markup Language)作为一种标记语言,广泛应用于数据交换、配置文件和文档存储等领域。在Java环境中,解析XML文档时,我们通常会遇到各种库,其中DOM4J是一个非常流行...
在这个例子中,我们将深入探讨如何使用DOM解析XML文件,以理解和掌握XML文档的结构,并进行数据提取、修改和创建。 首先,XML(Extensible Markup Language)是一种标记语言,用于存储和传输数据,具有自描述性和...
DOM(Document Object Model)是处理XML文档的一种标准API,它将XML文档表示为一棵可操作的节点树,使得我们可以方便地对XML数据进行创建、查询、修改和删除。下面我们将深入探讨DOM解析XML以及如何创建XML。 DOM...
- `stax-x.x.x.jar`:STAX(Streaming API for XML)是一种流式XML解析API,允许程序逐个处理XML事件,提供了比SAX更高的灵活性和性能。 在实际项目中,为了使用DOM4J解析XML,需要将这些jar包加入到项目的类路径中...
XML解析主要有两种方式:DOM(文档对象模型)和SAX(简单API for XML)。DOM解析会将整个XML文档加载到内存中形成一棵树形结构,方便访问任意节点,但内存消耗大;SAX解析则采用事件驱动,逐行读取XML,适合处理大型...
换句话说:XML DOM 是用于获取、更改、添加或删除 XML 元素的标准。 模块简介: 1、XMLDOMDocument类: XML对象文档 ->操作创建或读写(元素、节点、属性、注释)等 2、IXMLDOMNode类:每个元素或节点基本都会有的...
- 解析XML:如何使用DOM解析器加载XML文件,并将之转换为DOM树。 - 遍历和查询DOM:`getElementsByTagName()`, `getElementById()`, `getElementsByClassName()`等方法的使用。 - 操作DOM:添加、删除和修改节点,...
DOM解析器还允许我们修改现有节点的属性,添加或删除节点。例如,你可以用`setAttribute()`方法更改元素的属性,或者用`createElement()`创建新的元素节点,`appendChild()`将其添加到父节点。 在Android项目中,`...
3. **结点操作**:DOM解析器支持对XML节点的各种操作,如创建、删除、复制和移动。例如,创建一个新的元素并添加到文档中: ```csharp XmlElement newElement = doc.CreateElement("newElement"); doc....
Java DOM4J解析XML是一种常见的处理XML文档的技术,它提供了灵活且高效的API,使得开发者能够方便地读取、写入、修改以及操作XML文件。DOM4J是Java中一个非常强大的XML处理库,它结合了DOM、SAX和JDOM的优点,同时也...
Jaxen可以与多种XML解析器(如DOM、DOM4J、JDOM等)协同工作,提供跨平台的XPath支持。 总结来说,DOM4J是一个全面且易用的XML处理工具,广泛应用于Java开发中。通过`dom4j-1.6.1.jar`和`jaxen-1.1.1.jar`这两个jar...
5. **事件驱动解析(SAX)**:除了传统的DOM解析外,DOM4J还支持SAX解析器,这种解析方式适用于处理大型XML文件,因为它不需要一次性加载整个文档到内存。 6. **Namespace支持**:DOM4J提供了对XML命名空间的全面...
- **简介**:DOM(Document Object Model)是另一种常用的XML解析技术,它将整个XML文档加载到内存中,并构建一个树状结构,允许程序对文档进行任意操作。 - **特点**: - **灵活性高**:可以任意访问和修改文档中的...
在选择XML解析方式时,需要考虑文件大小、内存限制以及操作需求。SAX适合处理大文件并进行只读操作;DOM适用于需要快速查找和修改数据的场景,但需消耗更多内存;DOM4J则提供了更高级的功能和更友好的API,适合复杂...