`
563525042
  • 浏览: 49817 次
  • 性别: 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

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

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

    Java完整随笔(学习)

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

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

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

    随笔-MySQL5.7.15源代码方式安装文档

    - 使用 `firewall-cmd --permanent --add-port=3306/tcp` 和 `firewall-cmd --reload` 命令打开 3306 端口,并使更改立即生效。 通过以上步骤,我们完成了 MySQL 5.7.15 的源代码安装过程。在实际操作过程中,可能...

    【爱,因感觉而存在随笔】初冬的感觉随笔.rar

    很抱歉,根据您提供的信息,标题和描述似乎与IT行业知识并不相关,它们更像是文学作品或者个人随笔的名称。不过,既然您提到了“标签”是“教育”,我可以假设这里可能是指一篇关于教育理念或者情感教育的随笔。然而...

    教师研修随笔感言4.doc

    吴怀全在其教师研修随笔感言四中,详细探讨了教师专业发展的几个核心要素,包括不断更新自我、优化教学理念、建立良好的师生关系以及通过研修进行反思与提升。 首先,教师必须成为终身学习者,不断追求自我更新和...

    Word模板-随笔笔记.docx

    Word模板-随笔笔记.docx Word模板-随笔笔记.docx是微软Office软件Word中的一种模板文件,主要用于快速记录和笔记。下面是该模板的详细知识点: 模板的作用 Word模板-随笔笔记.docx的主要作用是提供一个快速记录和...

Global site tag (gtag.js) - Google Analytics