`
563525042
  • 浏览: 49476 次
  • 性别: Icon_minigender_1
  • 来自: 厦门
社区版块
存档分类
最新评论

随笔用dom4j建立,修改XML文档,

    博客分类:
  • java
阅读更多
package com.rbt.action;

import java.io.File;
import java.io.FileWriter;
import java.io.PrintWriter;
import java.util.Iterator;
import java.util.List;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

import org.apache.struts2.ServletActionContext;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;

import com.rbt.common.util.FileUtil;
import com.rbt.common.util.PropertiesUtil;
import java.io.IOException;

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 org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

public class RegularlyUpdatedAction extends BaseAction {

	// 获取系统根目录
	static final String CLASS_PATH = PropertiesUtil.getClassPath();
	// 获取标签sql配置文件
	private static String file_names = "quartz_job.xml";
	private static String file_path = CLASS_PATH + file_names;
	private String allXmldateString = "";
	private String redXmlDateString = "";
	private String opdate;
	private String upallXmldataString = "";
	private static String xmlutfString = "<?xml version=\"1.0\" encoding=\"gb2312\"?>";
	private static String xmlnameString = "name";
	private static String xmlquartzString = "quartz";
	private static String xmldescriptionString = "mydescription";
	private static String xmlgroupString = "group";
	private static String xmljob_classString = "job-class";
	private static String xmljob_groupString = "job-group";
	private static String xmlcron_expressionString = "cron-expression";
	private static String xmltriggerString = "trigger";
	private static String xmljob_nameString = "job-name";
	private static String xmljob_detailString = "job-detail";
	private static String xmljobString = "job";
	private static String xmlcronString = "cron";
	FileUtil fileUtil;

	/**
	 * 方法描述:定时更新数据
	 * 
	 * @return
	 * @throws Exception
	 */
	public String list() throws Exception {
		readXML();
		if (allXmldateString != null && !allXmldateString.equals("")
				&& allXmldateString.length() > 4) {
			allXmldateString = allXmldateString.substring(0, allXmldateString
					.length() - 4);
		}
		if (redXmlDateString != null && !redXmlDateString.equals("")
				&& redXmlDateString.length() > 4) {
			redXmlDateString = redXmlDateString.substring(0, redXmlDateString
					.length() - 4);
		}
		//System.out.println("我需要的XML值:" + allXmldateString);
		return SUCCESS;
	}

	/**
	 * 方法描述:读取XML文件信息
	 */
	public void readXML() {
		try {
			File file = new File(file_path);// 创建文件对象
			SAXReader reader = new SAXReader();// 创建SAX阅读器
			Document doc = reader.read(file);// 读取内容生成Document对象
			Element root = doc.getRootElement();// 取得根节点
			search(root);// 开始遍历
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	// 递归遍历
	private void search(Element root) {
		String eNameString = "";
		String evalueString = "";
		Iterator it_element = root.elementIterator();// 将根节点下包含的元素组织成一个迭代器
		// 迭代
		while (it_element.hasNext()) {
			Element element = (Element) it_element.next();
			if (!element.getText().equals("")) {
				// System.out.println(element.getName() + "==节点的值是=="
				// + element.getText());
				if (element.getName().equals(xmlnameString)) {
					eNameString += element.getName() + "=" + element.getText()
							+ "##";
				}
				if (element.getName().equals(xmldescriptionString)) {
					eNameString += element.getName() + "=" + element.getText()
							+ "##";
					evalueString += element.getText() + "##";
				}
				if (element.getName().equals(xmlgroupString)) {
					eNameString += element.getName() + "=" + element.getText()
							+ "##";
				}
				if (element.getName().equals(xmljob_classString)) {
					eNameString += element.getName() + "=" + element.getText()
							+ "##";
				}
				if (element.getName().equals(xmljob_nameString)) {
					eNameString += element.getName() + "=" + element.getText()
							+ "##";
				}
				if (element.getName().equals(xmljob_groupString)) {
					eNameString += element.getName() + "=" + element.getText()
							+ "##";
				}
				if (element.getName().equals(xmlcron_expressionString)) {
					eNameString += element.getName() + "=" + element.getText()
							+ "##";
					evalueString += element.getText() + "##";
				}
			} else {
				System.out.println(element.getName() + "==节点");
			}
			search(element);// 递归调用
		}
		if (!eNameString.equals("")) {
			allXmldateString += eNameString + "&&";
		}
		if (!evalueString.equals("")) {
			redXmlDateString += evalueString + "&&";
		}
	}

	/**
	 * AJAX定时更新
	 * 
	 * @throws Exception
	 */
	public void updatedRegularly() throws Exception {
		HttpServletRequest request = ServletActionContext.getRequest();
		HttpServletResponse response = ServletActionContext.getResponse();
		request.setCharacterEncoding("UTF-8");
		response.setCharacterEncoding("UTF-8");
		PrintWriter out = ServletActionContext.getResponse().getWriter();
		String outputString = "1";
		try {
			File file = new File(file_path);// 创建文件对象
			SAXReader reader = new SAXReader();// 创建SAX阅读器
			Document doc = reader.read(file);// 读取内容生成Document对象
			/*
			 * 调用ModiXMLFiles()更新XML
			 */
			ModiXMLFiles(doc);
		} catch (Exception e) {
			// TODO: handle exception
			outputString = "2";
		}
		out.write(outputString);
		/*
		 * 调用modifXML()更新XML
		 */
		// try {
		// String filecontentString = modifXML();
		// fileUtil = new FileUtil();
		// fileUtil.writeTxt(CLASS_PATH, file_names, filecontentString);
		// File file = new File(file_path);// 创建文件对象
		// System.out.println("文件:" + file_names + "写入成功!");
		// } catch (Exception e) {
		// // TODO: handle exception
		// System.out.println("文件:" + file_names + "写入失败!");
		// outputString = "2";
		// }
		/*
		 * 调用modifXML()更新XML
		 */
		// String filecontentString = modifXML();
		// OutputFormat format = OutputFormat.createPrettyPrint();
		// /** 指定XML字符集编码 */
		// format.setEncoding("gb2312");
		// Document document = DocumentHelper.parseText(filecontentString);
		// XMLWriter writer = new XMLWriter(new FileWriter(file_path),format);
		// writer.write(document);
		// writer.close();
		/*
		 * 调用ModiXMLFile()更新XML
		 */
		// ModiXMLFile(file_path,file_path);
		

	}

	public void ModiXMLFiles(Document document) throws IOException {
		Element root = document.getRootElement(); // 得到根节点目录
		Iterator iter = root.elementIterator();
		String[] repvalueStrings = opdate.split("@@");
		Integer num = 0;
		//System.out.println("\r\n****** 获取的数据如下 ******");
		while (iter.hasNext()) {
			Element titleElement = (Element) iter.next();
			//System.out.println(titleElement.getName());
			// 读取xml的job元素
			if (titleElement.getName().equals(xmljobString)) {
				Iterator iter1 = titleElement.elementIterator();
				while (iter1.hasNext()) {
					Element titleElement1 = (Element) iter1.next();
					//System.out.println("1=:" + titleElement.getName());
					// 读取xml的trigger元素
					if (titleElement1.getName().equals(xmltriggerString)) {
						Iterator iter2 = titleElement1.elementIterator();
						while (iter2.hasNext()) {
							Element titleElement2 = (Element) iter2.next();
							//System.out.println("2=:" + titleElement2.getName());
							// 读取xml的cron元素
							if (titleElement2.getName().equals(xmlcronString)) {
								Iterator iter3 = titleElement2.elementIterator();
								while (iter3.hasNext()) {
									Element titleElement3 = (Element) iter3.next();
									//System.out.println("3=:"+ titleElement3.getName());
									// 读取xml的cron_expression元素
									if (titleElement3.getName().equals(xmlcron_expressionString)) {
										if (repvalueStrings[num] != null&& !repvalueStrings[num].toString().equals("")) {
											titleElement3.setText(repvalueStrings[num].toString());
										}
										num = num + 1;
									}
								}
							}
						}
					}
				}
			}
		}
		// 输出全部原始数据,在编译器中显示
		OutputFormat format = OutputFormat.createPrettyPrint();
		/** 指定XML字符集编码 */
		format.setEncoding("gb2312");
		// 输出全部原始数据,并用它生成新的我们需要的XML文件
		XMLWriter writer = new XMLWriter(new FileWriter(new File(file_path)),format);
		writer.write(document); // 输出到文件
		writer.close();
	}

	private String modifXML() {
		String allnewxmString = "";
		readXML();
		if (allXmldateString != null && !allXmldateString.equals("")
				&& allXmldateString.length() > 4) {
			allXmldateString = allXmldateString.substring(0, allXmldateString
					.length() - 4);
		}
		String newtitixmlString = xmlutfString;
		newtitixmlString += "<" + xmlquartzString + ">";
		String endtitlexmlString = "</" + xmlquartzString + ">";
		String newxmString = "";
		String[] strxmltexts = allXmldateString.split("##&&");
		String[] repvalueStrings = opdate.split("@@");
		for (int i = 0, ii = 0; i < strxmltexts.length; i = i + 2, ii++) {
			newxmString += "<" + xmljobString + ">";
			String models1 = "";
			String models2 = "";
			models1 = strxmltexts[i].toString();
			models2 = strxmltexts[i + 1].toString();
			String[] strmodel1 = models1.split("##");
			String[] strmodel2 = models2.split("##");
			newxmString += "<" + xmljob_detailString + ">";
			for (int j = 0; j < strmodel1.length; j++) {
				String[] strmodel11 = strmodel1[j].split("=");
				if (strmodel11 != null && strmodel11.length != 0) {
					if (strmodel11[0] != null) {
						newxmString += "<" + strmodel11[0].toString() + ">";
						if (strmodel11[1] != null) {
							newxmString += strmodel11[1].toString();
						}
						newxmString += "</" + strmodel11[0].toString() + ">";
					}
				}
			}
			newxmString += "</" + xmljob_detailString + ">";
			newxmString += "<" + xmltriggerString + ">";
			newxmString += "<" + xmlcronString + ">";
			for (int s = 0; s < strmodel2.length; s++) {
				String[] strmodel12 = strmodel2[s].split("=");
				if (strmodel12 != null && strmodel12.length != 0) {
					if (strmodel12[0] != null) {
						newxmString += "<" + strmodel12[0].toString() + ">";
						if (strmodel12[1] != null) {
							if (strmodel12[0].equals(xmlcron_expressionString)) {
								if (repvalueStrings[ii] != null) {
									newxmString += repvalueStrings[ii]
											.toString();
								} else {
									newxmString += strmodel12[1].toString();
								}
							} else {
								newxmString += strmodel12[1].toString();
							}
						}
						newxmString += "</" + strmodel12[0].toString() + ">";
					}
				}
			}
			newxmString += "</" + xmlcronString + ">";
			newxmString += "</" + xmltriggerString + ">";
			newxmString += "</" + xmljobString + ">";
		}
		allnewxmString = newtitixmlString + newxmString + endtitlexmlString;
		return allnewxmString;
	}

	/**
	 * 修改XML文件中内容,并另存为一个新文件 重点掌握dom4j中如何添加节点,修改节点,删除节点
	 * 
	 * @param filename
	 *            修改对象文件
	 * @param newfilename
	 *            修改后另存为该文件
	 * @return 返回操作结果, 0表失败, 1表成功
	 */
	public int ModiXMLFile(String filename, String newfilename) {
		int returnValue = 0;
		String[] repvalueStrings = opdate.split("@@");
		int num = 0;
		try {
			SAXReader saxReader = new SAXReader();
			Document document = saxReader.read(new File(filename));
			/**
			 * 修改内容: 修改cron-expression项内容
			 */
			List list = document.selectNodes("cron-expression");
			Iterator iter = list.iterator();
			if (iter.hasNext()) {
				Element ownerElement = (Element) iter.next();
				ownerElement.setText(repvalueStrings[num]);
				num = num + 1;
			}
			try {
				OutputFormat format = OutputFormat.createPrettyPrint();
				/** 指定XML字符集编码 */
				format.setEncoding("gb2312");
				/** 将document中的内容写入文件中 */
				XMLWriter writer = new XMLWriter(new FileWriter(new File(
						newfilename)), format);
				writer.write(document);
				writer.close();
				/** 执行成功,需返回1 */
				returnValue = 1;
			} catch (Exception ex) {
				ex.printStackTrace();
			}

		} catch (Exception ex) {
			ex.printStackTrace();
		}
		return returnValue;
	}

	public int formatXMLFile(String filename) {
		int returnValue = 0;
		try {
			SAXReader saxReader = new SAXReader();
			Document document = saxReader.read(new File(filename));
			XMLWriter output = null;
			/** 格式化输出,类型IE浏览一样 */
			OutputFormat format = OutputFormat.createPrettyPrint();
			/** 指定XML字符集编码 */
			format.setEncoding("utf-8");
			output = new XMLWriter(new FileWriter(new File(filename)), format);
			output.write(document);
			output.close();
			/** 执行成功,需返回1 */
			returnValue = 1;
		} catch (Exception ex) {
			ex.printStackTrace();
		}
		return returnValue;
	}

	public String getAllXmldateString() {
		return allXmldateString;
	}

	public void setAllXmldateString(String allXmldateString) {
		this.allXmldateString = allXmldateString;
	}

	public String getRedXmlDateString() {
		return redXmlDateString;
	}

	public void setRedXmlDateString(String redXmlDateString) {
		this.redXmlDateString = redXmlDateString;
	}

	public String getOpdate() {
		return opdate;
	}

	public void setOpdate(String opdate) {
		this.opdate = opdate;
	}

	public String getUpallXmldataString() {
		return upallXmldataString;
	}

	public void setUpallXmldataString(String upallXmldataString) {
		this.upallXmldataString = upallXmldataString;
	}

}
分享到:
评论

相关推荐

    Log4j2手册阅读随笔(Log4j2新特性)

    Log4j2是一款广泛使用的Java日志记录框架,它的出现是为了替代早期的Log4j,提供了更为高效、灵活和安全的日志处理能力。这篇随笔主要探讨了Log4j2的一些新特性,对于理解并利用这些特性来优化日志管理至关重要。 ...

    【Java - 框架 - Knife4j】随笔

    【Java - 框架 - Knife4j】随笔 在Java Web开发中,文档的生成与维护是一项重要但繁琐的工作。Knife4j,作为一款专门为Java RESTful API设计的文档增强工具,它极大地简化了这个过程,为开发者带来了诸多便利。本篇...

    随笔小记文档及若干代码

    随笔小记的文档,自己记录的一些文档,仅供参考

    java记录随笔

    XML 结构化信息传输和存储的地位日益重要,XML 文档操作工具(如 DOM、Digester、SAX 等)的使用愈发重要。采用 XML schema 来设计 XML 文档格式,然后采用 Java binding 来生成 Java bean 将成为主要编程模式。这...

    国培随笔MicrosoftWord文档.doc

    【Microsoft Word文档与国培随笔】 国培随笔中提到了作者参与“国培”方案,这是一种国家针对教师的专业发展进行的培训项目。在这个过程中,作者深入学习了Microsoft Word文档的相关知识,以及如何将其应用到教学...

    PyQt(Python+Qt)学习随笔:PyQt帮助文档导入assistant后离线查阅.rar

    本篇随笔将探讨如何将PyQt的帮助文档导入到assistant中,以便在离线状态下查阅,提升开发效率。 首先,理解PyQt的基础知识至关重要。PyQt是由Riverbank Computing开发的,它将Qt库与Python无缝对接。Qt库是跨平台的...

    js随笔提示

    4. **异步处理**:如果内容是从服务器动态获取的,可能会使用AJAX(Asynchronous JavaScript and XML)或者现代的fetch API,实现异步请求,避免阻塞用户界面。 5. **用户体验优化**:为了提供更好的用户体验,可能...

    iOS开发使用XML解析网络数据

    前言:本篇随笔介绍的是XML解析。 正文: 1、XML解析方式有2两种: DOM:一次性将整个XML数据加载进内存进行解析,比较适合解析小文件SAX:从根元素开始,按顺序一个元素一个元素往下解析,比较适合解析大文件 2、...

    散文随笔【人间五月散文随笔】.rar

    4. **教育价值**:这类散文随笔可能包含丰富的文化内涵,有助于提升读者的文化素养,通过作者的视角,引导读者对生活、人性、社会进行深度思考,对教育和自我提升具有积极意义。 5. **人间五月**:作为一个主题,...

    散文随笔【黄牛散文随笔】.rar

    "散文随笔【黄牛散文随笔】.pdf"是压缩包内唯一的一个文件,表明这是一部完整的PDF文档,包含了黄牛的所有散文随笔。PDF格式保证了内容的格式稳定,便于在各种设备上阅读,同时也方便分享和保存。 【详细知识点】 ...

    Extjs Tree + JSON + Struts2 示例源代码

    dom4j-1.6.1.jar ezmorph-1.0.4.jar freemarker-2.3.8.jar javassist-3.8.1.jar json-lib-2.2.1-jdk15.jar log4j-1.2.13.jar ognl-2.6.11.jar struts2-core-2.0.11.jar xml-apis-1.0.b2.jar xwork-2.0.4.jar

    6中高段随笔习作的新思路.docx

    【描述】: 该文档讨论了针对中高年级学生随笔习作教学面临的问题及改进策略,主要关注现状分析、问题探讨以及解决方法。 【主要内容】: 在当前的中高段随笔习作教学中,存在一系列挑战。经过调查发现,虽然随笔化...

    校园竹林随笔精选.doc

    【校园竹林随笔精选.doc】是一份包含校园生活情感的文档,主要讲述了教师与学生之间的心灵交流和教育故事。文档中通过两篇随笔展现了教师对学生内心世界的关注和理解,以及教师自身的成长和感悟。 第一篇随笔中,...

    散文随笔_生活三部曲散文随笔.rar

    【标题】"散文随笔_生活三部曲散文随笔.rar"所指的是一份包含散文随笔作品的压缩文件,特别关注的是生活的主题。在IT领域,这可能涉及到电子书、数字出版或个人资料存储等方面的知识。"rar"是一种常见的文件压缩格式...

    [小忆故乡随笔]故乡随笔.rar

    总的来说,【小忆故乡随笔】通过PDF文档的形式,为读者提供了一次跨越时空的心灵之旅,它不仅仅是一本关于故乡的随笔集,更是一份教育素材,让我们在阅读中感受故乡的气息,理解乡土文化,同时也学习到如何用文字...

    教育随笔4.doc

    这篇教育随笔以《今日,你笑了吗》为题,主要探讨了在幼儿教育工作中保持积极心态的重要性。作者张弘通过实例阐述了教师在面对孩子淘气、同事矛盾以及家长不理解时,如何运用理解和宽容的心态来处理问题,强调了微笑...

    Java完整随笔(学习)

    Java是一种广泛使用的面向对象的编程语言,以其跨平台、高性能和丰富的类库而闻名。"Java完整随笔(学习)"可能包含了一系列关于Java编程的基础到高级概念的笔记,是学习Java的好资源。以下是一些可能涵盖的重要知识...

    无限菜单之 xml+popup 版(IE5.5+)

    Xml真是好东西,在Web控件中,可以得到灵活的运用(在我的上篇随笔《xml+xsl+htc,web控件开发的理想组合》中,已经简单提到了xml+xsl+htc的理想组合),在这里也不例外,先用Xml来定义好菜单的数据menu.xml: ...

Global site tag (gtag.js) - Google Analytics