java操作XML

   最近一直在做高效平台的框架,其实意识到我要做一个简单的框架的时候是在我已经做完我认为的一版界面之后,开始以为我要做的是一个可配置的首页展示,但是吭哧吭哧做了两个星期,大概功能实现了之后,才发现要做的不是这个,哎,需求不清楚害死人啊,但是这两个星期并没有白白浪费,也从中学到了很多东西,下面主要介绍读取XML。

  在做系统的时候,经常会遇到读取xml的需求,一开始是读取,于是我上网开始查询读取,接着查询删除,接着查询修改,当把这些代码查的差不多的时候,我发现,我为什么不把这些的操作都封装到一个类里,使用的时候直接调用,岂不是更好,感觉之前脑袋都秀逗了,分别查了那么多,还一个个的调试,抱着这个心态继续上网查(因为我真心感觉网上肯定有,如果我自己封装的话脑袋就真的进水了)。

  源代码展示:

package com.gxpt.struts2;
import java.io.File;
import java.io.FileWriter;

import java.util.Iterator;
import java.util.List;
import java.util.Map;

import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
public class testAddDeleteXML {
private Document document;
	private String filePath; //文件所在的实际物理路径
	//private WriteLog writelog;
	public static void main(String[] args) throws DocumentException {
		//String filepath = System.getProperty("user.dir")+"/XmlFiles/LocalServicesConfig.xml";
		String filepath ="F:\\JAVA项目\\高校平台\\demo\\gxpt\\WebContent\\limits\\manager.txt";
		testAddDeleteXML operator = new testAddDeleteXML(filepath);
		operator.getXmlFile();
	
		
//		Map map = new HashMap();
//		map.put("id", "m1");
//		map.put("name","module1");
//		map.put("url", "index1.jsp");
//		operator.addChild("div", "div9","module", "",map);
		//operator.updateChild("style", "", "div", "asdfasdf",1);		

		operator.deleteChildOne("style", "","div","div11");
		//operator.deleteChild("div", "div9","module");
		//String str = operator.getChild("div", "div8", "module");
		//System.out.println(str);
		//Element root = document.getRootElement();//获取根节点名称
		 
		
	}
	
	
	
	public  testAddDeleteXML(String filepath){
		this.document = null;
		this.filePath = filepath;
		//writelog = new WriteLog();
	}
	/** 
	* 创建XML文件
	* @param rootName:根节点名称
	*/
	public void createXMLFile(String rootName) {
	   if(!fileExist()){
	    this.document = DocumentHelper.createDocument();
	    this.document.addElement(rootName);
	    saveXMLFile(this.document);
	   }
	}
/**
* 获取已存在的XML文档
* @return
*/
	public Document getXmlFile() {
	   if (fileExist()) {
	    SAXReader reader = new SAXReader(); 
	    try {
	     this.document = reader.read(new File(filePath));
	    } catch (DocumentException e) {
	   //  String loginfo = StackTraceToString.getExceptionTrace(e);
	   //  writelog.writeLogToEnd("LocalServerManager", loginfo);
	    }finally{
	     reader = null;
	    }
	   } else {
	    //写日志
	   // String loginfo = "XML file does not exist,read error!";
	  //  writelog.writeLogToEnd("LocalServerManager",loginfo);
	    System.exit(0);
	   }
	   return this.document;
	}
	
	/**
	* 添加元素
	* @param fatherPath:父节点名称
	* @param fatherattr:父节点属性
	* @param childName:要添加的节点名称
	* @param childValue:要添加的节点值
	*/
	public void addChild(String fatherNode, String fatherAttr,String childName, String childValue,Map mapAttr) {
	   ChildOperator(fatherNode,fatherAttr,childName,childValue,"add",mapAttr,0);
	}
	/**
	* 修改元素
	* @param fatherPath:父节点名称
	* @param fatherattr:父节点属性
	* @param childName:要修改的节点名称
	* @param childValue:要修改成的节点值
	*/
	public void updateChild(String fatherNode, String fatherAttr,String childName, String childValue,int updatId) {
	   ChildOperator(fatherNode,fatherAttr,childName,childValue,"update",null,updatId);
	}
	/**
	* 删除元素
	* @param fatherPath:父节点名称
	* @param fatherattr:父节点属性
	* @param childName:要删除的节点名称
	*/
	public void deleteChild(String fatherNode, String fatherAttr,String childName) {
	   ChildOperator(fatherNode,fatherAttr,childName,"","delete",null,0);
	}
	/**
	* 删除元素
	* @param fatherPath:父节点名称
	* @param fatherattr:父节点属性
	* @param childName:要删除的节点名称
	*/
	public void deleteChildAll(String fatherNode, String fatherAttr,String childName) {
	   ChildOperator(fatherNode,fatherAttr,childName,"","deleteAll",null,0);
	}
	
	
	/**
	* 删除某个元素
	* @param fatherPath:父节点名称
	* @param fatherattr:父节点属性
	* @param childName:要删除的节点名称
	*/
	public void deleteChildOne(String fatherNode, String fatherAttr,String childName,String childValue) {
	   ChildOperator(fatherNode,fatherAttr,childName,childValue,"deleteOne",null,0);
	}
	/**
	* 获取某个元素数值
	* @param fatherPath:父节点名称
	* @param fatherattr:父节点属性
	* @param childName:要删除的节点名称
	*/
	public String getChild(String fatherNode, String fatherAttr,String childName) {
	   String result = "";
	   result = ChildOperator(fatherNode,fatherAttr,childName,"","get",null,0);
	   return result;
	}
	/**
	* 子节点操作
	* @param fatherNode:父节点名称
	* @param fatherAttr:父节点属性
	* @param childName:要修改的节点
	* @param childValue:修改后的节点值
	* @param operator: 要执行的操作名称
	*/
	private synchronized String ChildOperator(String fatherNode, String fatherAttr,String childName, String childValue,String operator,Map mapAttr,int updateId) {
	   String result="";
	   if (this.document == null) {
		  
		    return "null";
	   }
	   Element root = this.document.getRootElement();//获取根节点名称
	  
	   if(!root.getName().equals(fatherNode)){ //如果不是在根节点下添加
		   result = XmlElementOperator(root,fatherNode,fatherAttr,childName,childValue,operator,mapAttr);
	   }else{
		    if(operator.equals("add")){
			     Element childelement = root.addElement(childName);//根节点不存在元素属性值
			     childelement.setAttributeValue("id",childValue);
			    
			     
			     saveXMLFile(this.document);
		    }else if(operator.equals("update")){
			     List childelements = root.elements(childName);
			    // for(Iterator childs=childelements.iterator();childs.hasNext();){
				   //   Element everyone = (Element)childs.next();
				    //  everyone.setText(childValue); //修改该元素值
				   //   everyone.setAttributeValue("id",childValue);
			     	Element everyone = (Element)childelements.get(updateId);
			     	everyone.setAttributeValue("id",childValue);
			   //  }
			     saveXMLFile(this.document);
		    }else if(operator.equals("delete")){
		    	List childelements = root.elements(childName);//获取当前节点下的所有子节点,判断其值,以进行修改
		    	for(Iterator childs=childelements.iterator();childs.hasNext();){
		    			Element everyone = (Element)childs.next();
		    			List childelements1 = everyone.elements("module");
		    			for(Iterator childs1=childelements1.iterator();childs1.hasNext();){
		    				Element everyone1 = (Element)childs1.next();
		    				everyone.remove(everyone1);
		    			}
		    			
		    			
		    	}
		    	
		    	saveXMLFile(this.document);
		    }else if(operator.equals("get")){
		    	List childelements = root.elements(childName);//获取当前节点下的所有子节点,判断其值,以进行修改
		    	
		    	for(Iterator childs=childelements.iterator();childs.hasNext();){
		    		Element everyone = (Element)childs.next();
		    		
		    		result = everyone.getText();
		    	}
		    	saveXMLFile(this.document);
		    }else if(operator.equals("deleteOne")){
		    	
		    	List childelements = root.elements(childName);//获取当前节点下的所有子节点,判断其值,以进行修改
		    	
		    	for(Iterator childs=childelements.iterator();childs.hasNext();){
		    			Element everyone = (Element)childs.next();
		    			String  divElement = everyone.attributeValue("id");
		    			if(divElement.equals(childValue)){
		    				root.remove(everyone);
		    			}
		    	}
		    	saveXMLFile(this.document);
		    }else if(operator.equals("deleteAll")){
		    	List childelements = root.elements();//获取当前节点下的所有子节点,判断其值,以进行修改
		    	
		    	for(Iterator childs=childelements.iterator();childs.hasNext();){
	    			Element everyone = (Element)childs.next();
	    			List childeDiv = everyone.elements();
	    			for(Iterator childsDiv=childeDiv.iterator();childsDiv.hasNext();){
		    			Element everyoneDiv = (Element)childsDiv.next();
		    			everyone.remove(everyoneDiv);
	    			}
		    	}
	    	}
	    	saveXMLFile(this.document);
		    
	   }
	   return result;
	}	
	/**
	* 递归元素操作
	* @param element:要递归的元素
	* @param fatherNode:父节点名称
	* @param fatherAttr:父节点属性
	* @param childName:要进行操作的节点
	* @param childValue:操作后的节点值
	* @param operator: 要执行的操作名称
	*/
	private synchronized String XmlElementOperator(Element element,String fatherNode,String fatherAttr,String childName,String childValue,String operator,Map mapAttr){
	   String result = "";
	   List elements = element.elements();
	   for(Iterator it=elements.iterator();it.hasNext();){
		   Element currentelement = (Element)it.next();
		   if(!currentelement.getName().equals(fatherNode)){ //当前元素并不是我们要查找的父元素时,继续查找
			   XmlElementOperator(currentelement,fatherNode,fatherAttr,childName,childValue,operator,mapAttr);//递归调用
		   }else{
			   if(currentelement.attributeCount()>0){ //当前元素存在属性值时
				   for(Iterator list=currentelement.attributeIterator();list.hasNext();){ //遍历属性值
					   Attribute attr = (Attribute)list.next(); //获取属性值队列中的第一个元素
					   if(attr.getValue().equals(fatherAttr)){//根据属性值确定惟一的父元素
						   if(operator.equals("add")){//添加元素
							   Element childelement = currentelement.addElement(childName); //给当前元素添加一个子元素
							  
							   childelement.setText(childValue); //设置子元素的数值
								Iterator itmapAttr = mapAttr.keySet().iterator();
							   while(itmapAttr.hasNext()){
									String key = (String) itmapAttr.next();
									String value = mapAttr.get(key).toString();
									 childelement.setAttributeValue(key,value);
								
								}
							  
//							   childelement.setAttributeValue("id", "m1");
//							     childelement.setAttributeValue("name", "module1");
//							     childelement.setAttributeValue("url", "index1.jsp");
						   }else if(operator.equals("update")){//修改某个元素
							   List childelements = currentelement.elements(childName);//获取当前节点下的所有子节点,判断其值,以进行修改
							   for(Iterator childs=childelements.iterator();childs.hasNext();){
								   Element everyone = (Element)childs.next();
								   everyone.setText(childValue); //修改该元素值
							   }
						   }else if(operator.equals("delete")){ //删除某个指定的元素
							  
							   List childelements = currentelement.elements();//获取当前节点下的所有子节点,判断其值,以进行修改
							   
							   for(Iterator childs=childelements.iterator();childs.hasNext();){
								   Element everyone = (Element)childs.next();
								   currentelement.remove(everyone);
							   }
						   }else if(operator.equals("get")){
							   List childelements = currentelement.elements(childName);//获取当前节点下的所有子节点,判断其值,以进行修改
							   for(Iterator childs=childelements.iterator();childs.hasNext();){
								   	Element everyone = (Element)childs.next();
								   //	result = everyone.getText();
								   	result =everyone.attributeValue("id")+","+result ;
							   }
						   }
						   else{
							   //写日志
							   //  String loginfo = "XmlFile Operator not exists!";
							   //  writelog.writeLogToEnd("LocalServerManager",loginfo);
						   }
					   }
				   }
			   }
		   }
	   }
	   saveXMLFile(this.document);
	   return result;
	}
	/**
	* 保存XML文件
	* @param document: XML文件名
	*/
	private void saveXMLFile(Document document) {
	   try {
	    OutputFormat format = OutputFormat.createPrettyPrint();
	    format.setEncoding("utf-8");
	    XMLWriter writer = new XMLWriter(new FileWriter(new File(filePath)),format);
	    writer.write(document);   
	    writer.close();
	   } catch (Exception e) {   
	   // String loginfo = StackTraceToString.getExceptionTrace(e);
	   // writelog.writeLogToEnd("LocalServerManager", loginfo);
	   }
	}
	/**
	* 判断XML文件是否存在. 
	* @param fileName
	* @return
	*/
	private boolean fileExist() {
	   java.io.File objFile = new java.io.File(this.filePath);
	   if (objFile.exists()) {
	    return true;
	   } else {
		    return false;
		}
	}
}

XML文件:

<?xml version="1.0" encoding="utf-8"?>


<style> 

  <div id="div8"> 

    <module id="m1" name="module1" url="index1.jsp"/>  
 
   <module id="m2" name="module2" url="index2.jsp"/>  

    <module id="m3" name="module3" url="index3.jsp"/> 
 
 </div> 
 
  <div id="div9"> 
  
  
  <module id="m9" name="module9" url="index3.jsp"/>
  
  <module id="m10" name="module10" url="index4.jsp"/>
 
   <module id="m11" name="module11" url="index5.jsp"/>
 
 </div> 

 </style>

解析:这里应用递归的方式来判断是对跟节点还是子节点的操作,相对比较清晰,这里用的是if判断来判断选择的是那种操作,如果变动相对较多,我感觉可以利用依赖注入,省去了if判断的麻烦,但是当时只是做了一个demo,没有更多的优化,如果有兴趣的话可以试一试。

总结:读取XML其实并不难,在写.NET系统的时候就写过关于xml的读取,但是当时真的就是一个一个的写,需要什么在哪个方法下写什么,不仅要写很多重复的代码,而且有一点问题需要重复的修改,所以,有时候,虽然实现了需求重要,但是怎么实现,同样重要!


java操作XML

上一篇:maven本地安装jar包


下一篇:Visual Studio 2010安装、配置及使用