MVC模式下xml文件的解析
第一次写blog,组织不当和出错的地方还请大家多担当哈。
java操作xml文件的方式中用的较多的有四种,DOM、SAX、JDOM、DOM4J。除第一种外其余的三种我都有试过,这后三种方案中我选择用SAX处理数据库的配置文件,用DOM4J处理我其余的一些数据文件,下面是我的筛选原由:
1) SAX解析器采用了基于事件的模型,分析能够立即开始,不用等待所有的数据被处理,同时也不需要将数据存储在内存中,所以这种解析方式的优点就是快,内存要求低,尤其对大的xml文件来讲。这种解析方式的缺点也很明显,不能随机访问xml文档,修改起来当然也不好实现。
2) JDOM是java特定文档模型,api简化易理解,但自身是没有解析器的,它用的是SAX的,所以是具有SAX的java规则,和DOM一样,它的性能在这四种方式中表现都不是太好。
3) DOM4J最初是JDOM的一个分支,但是它的性能是最好的,其复杂的api支持其对xml文件进行复杂的操作。
数据库配置文件只需要简单的读取,所以我选择SAX,而我要处理的数据xml文件,要做稍微复杂一点的工作,包括读取、添加、删除、修改、重写等,所以选择了DOM4J这种方式。这里我只简单说说我用DOM4J的操作。
在讲这个之前,我再提下我为什么要说MVC开发模式。MVC是web开发中很常用的一个模式,M代表modal是数据的模型与组织,V代表view是展现在用户面前的东西,C代表controller是M和V之间的控制层。我要操作的xml文件是在后台处理的,然后以json的格式传递到前端展示,前端的操作再传递到后台并对xml文件做相应的处理。大体的结构图如下:

视图中上面的html和js代表V,服务器中的Action文件可以理解为C,Factory和Bean可以理解为M,本文中我们重点关注M,其余的两部分就不做讨论了。
xml文件 test.xml:
<?xml version="1.0" encoding="GBK"?>
<jgs>
<jg id="jg1">
<id>1</id>
<len>7</len>
<wid>5</wid>
<hei>14</hei>
</jg>
<jg id="jg2">
<id>2</id>
<len>7</len>
<wid>5</wid>
<hei>14</hei>
</jg>
</jgs>
java代码JGBean.java:
package com.factory;
/**
* JG数据模型
* @author Echo
*/
public class JGBean {
private String id = "";
private String len = "";
private String wid = "";
private String hei = "";
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getWid() {
return wid;
}
public void setWid(String wid) {
this.wid = wid;
}
public String getHei() {
return hei;
}
public void setHei(String hei) {
this.hei = hei;
}
}
实现代码XMLHandler.java
package com.factory;
/**
* xml解析类
* @author Echo
*/
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import net.sf.json.JSONObject;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
public class XMLHandler {
private static XMLHandler instance = null;
private List<JGBean> jgList = new ArrayList<JGBean>();
private static Document d = null;
private String fileName = "test.xml";
public static XMLHandler getInstance(){
if(instance == null){
instance = new XMLHandler();
}
return instance;
}
public XMLHandler(){
if(jgList.size() == 0) loadXML();
}
public void loadXML(){
d = getXMLFile(fileName);
jgList = readXMLFile();
}
public Document getXMLFile(String fileName) {
Document document =null;
try {
SAXReader saxReader =new SAXReader();
File f = new File(getClass().getResource(fileName).getFile());
document = saxReader.read(f); //读取XML文件,获得document对象
} catch (Exception e) {
e.printStackTrace();
}
return document;
}
//读取xml文件元素名称和文本值
@SuppressWarnings("unchecked")
public List<JGBean> readXMLFile() {
Element root =d.getRootElement();
jgList.clear();
Iterator iter = root.elementIterator("jg"); // 获取根节点下的子节点
while (iter.hasNext()) {
JGBean jgb = new JGBean();
Element jg = (Element) iter.next();
jgb.setId(jg.elementTextTrim("id"));
jgb.setLen(jg.elementTextTrim("len"));
jgb.setWid(jg.elementTextTrim("wid"));
jgb.setHei(jg.elementTextTrim("hei"));
jg.setText(" ");
jgList.add(jgb);
}
return jgList;
}
@SuppressWarnings("unchecked")
public void modifyNode(String id){ //修改单个jg节点
Element root = d.getRootElement();
Iterator iter = root.elementIterator("jg"); // 获取根节点下的子节点
while (iter.hasNext()) {
Element jg = (Element) iter.next();
if(jg.getXPathResult(0).getText().equals(id)){
jg.getXPathResult(0).setText(9);//修改id为9
return;
}
}
}
public Element addNode(JSONObject json){ //添加机柜
Element root = d.getRootElement();
Element jg = root.addElement("jg");
Element id = jigui.addElement("id");
id.setText(json.getString("id"));
Element len = jigui.addElement("len");
len.setText(json.getString("len"));
Element wid = jigui.addElement("wid");
wid.setText(json.getString("wid"));
Element hei = jigui.addElement("hei");
hei.setText(json.getString("hei"));
updateDocument();
writeXML(fileName);
return jigui;
}
@SuppressWarnings("unchecked")
public Element deleteNode(String id){//删除机柜
Element root = d.getRootElement();
Iterator iter = root.elementIterator("jg"); // 获取根节点下的子节点
Element e = null;
while (iter.hasNext()) {
Element jg = (Element) iter.next();
if(jg.getXPathResult(0).getText().equals(id)){
e = jg;
root.remove(jg);
break;
}
}
updateDocument();
writeXML(fileName);
return e;
}
@SuppressWarnings("unchecked")
public Element updateNode(JSONObject json){ //修改单个节点
Element root = d.getRootElement();
Iterator iter = root.elementIterator("jg"); // 获取根节点下的子节点
Element e = null;
while (iter.hasNext()) {
Element jg = (Element) iter.next();
if(jg.getXPathResult(0).getText().equals(json.getString("id"))){
System.out.println(jg.getXPathResult(0).getText());
e = jg;
break;
}
}
updateDocument();
writeXML(fileName);
return e;
}
@SuppressWarnings("unchecked")
public void updateDocument(){
Element root = d.getRootElement();
Iterator iter = root.elementIterator("jg"); // 获取根节点下的子节点
int index = 0;
String id = "";
while (iter.hasNext()) {
Element jg = (Element) iter.next();
id = ++index + "";
jg.getXPathResult(0).setText(id);
}
}
public void writeXML(String fileName){
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("GBK"); // 指定XML编码
XMLWriter output;
try {
File f = new File(getClass().getResource(fileName).getFile());
output = new XMLWriter(new FileWriter(f),format);
output.write( d );
System.out.println("xml write success!");
output.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
jgList = readXMLFile(); //重新读取文件,更新list内容
}
}
MVC模式下xml文件的解析的更多相关文章
- JAVA读取XML文件并解析获取元素、属性值、子元素信息
JAVA读取XML文件并解析获取元素.属性值.子元素信息 关键字 XML读取 InputStream DocumentBuilderFactory Element Node 前言 最 ...
- JDOM方法实现对XML文件的解析
首先要下载JDOM.jar包,下载地址:http://download.csdn.net/detail/ww6055/8880371 下载到JDOM.jar包之后导入到工程中去. 实例程序: book ...
- MVC模式下My97DatePicker日期控件引用注意事项
My97DatePicker日期控件之前在用webform模式开发的时候,只要 <script language="javascript" type="text/j ...
- MongoDB学习笔记(三) 在MVC模式下通过Jqgrid表格操作MongoDB数据
看到下图,是通过Jqgrid实现表格数据的基本增删查改的操作.表格数据增删改是一般企业应用系统开发的常见功能,不过不同的是这个表格数据来源是非关系型的数据库MongoDB.nosql虽然概念新颖,但是 ...
- 类的反射及xml文件的解析
类的反射 xml文件的解析 .properties||.xml配置文件的创建及读取内容 //创建对象 Properties properties = new Properties(); //存储 pr ...
- 用SAX和PULL进行XML文件的解析与生成
XML解析有传统的dom方法还有Jsoup,SAX,PULL等,这里讲的是比较省内存的SAX和PULL方法.Android中极力推荐用PULL的方式来解析,我个人觉得pull确实比较简单,但其内部的逻 ...
- 【文件处理】xml 文件 DOM解析
一.Java解析xml.解析xml四种方法.DOM.SAX.JDOM.DOM4j.XPath 此文针对其中的DOM方法具体展开介绍及代码分析 sax.dom是两种对xml文档进行解析的方法(没有具体实 ...
- 【案例分享】使用ActiveReports报表工具,在.NET MVC模式下动态创建报表
提起报表,大家会觉得即熟悉又陌生,好像常常在工作中使用,又似乎无法准确描述报表.今天我们来一起了解一下什么是报表,报表的结构.构成元素,以及为什么需要报表. 什么是报表 简单的说:报表就是通过表格.图 ...
- 在MVC模式下通过Jqgrid表格操作MongoDB数据
看到下图,是通过Jqgrid实现表格数据的基本增删查改的操作.表格数据增删改是一般企业应用系统开发的常见功能,不过不同的是这个表格数据来源是非关系型的数据库MongoDB.nosql虽然概念新颖,但是 ...
随机推荐
- db file sequential read等待事件的一点研究
db file sequential read等待事件有3个参数:file#,first block#,和block数量. 这个等待事件有3个参数P1,P2,P3, 其中P1代表Oracle要读取的文 ...
- BZOJ1524: [POI2006]Pal
1524: [POI2006]Pal Time Limit: 5 Sec Memory Limit: 357 MBSubmit: 308 Solved: 101[Submit][Status] D ...
- [C#错误] 未找到类型或命名空间名称" " (是否缺少 using 指令或程序集引用?)
现象:编译项目时提示未找到类型或命名空间名称" " (是否缺少 using 指令或程序集引用?)解决方法:如果是未找到类型,检查是否引用了类型所在的命名空间,使用using指令.如 ...
- jquery 选择器 的学习,自己慢慢来
1//加载所有元素后,执行下列代码 <script type="text/javascript"> $(document).ready(function(){ //选择 ...
- 130+ essential vim commands
Basics :e filename Open filename for edition :w Save file :q Exit Vim :q! Quit without saving :x Wri ...
- Linq to Sql语法及实例大全
LINQ to SQL语句(1)之Where Where操作 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的 ,而判断条件就是它后面所接的 ...
- Python学习 1 一 Python2.75的安装及环境配置教程
Python2.75的安装及环境配置教程 Python的语法简洁,功能强大,有大量的第三方开发包(模块),非常适合初学者上手.同时Python不像java一样对内存要求非常高,适合做一些经常性的任务方 ...
- 让IE6,7,8支持HTML5新标签的方法
很多网站对网页进行重构的时候,提高标签的语义性,在网页中大量使用了section,article,header等HTML5新标签.考虑到目前win7自带的IE浏览器版本是IE8,而IE8不支持HTML ...
- Unity3D NGUI UIPlayTween控件(一)动态打开关闭窗口
利用NGUI自带的脚本控件实现按钮点击窗口滑动出现与隐藏. 创建界面 首先建立如下图的三个BUtton与三个Panel 绑定脚本 然后在每个Button上添加UIPlayTween脚本,在Intera ...
- NSString去掉火车和空格
// backString = [backString stringByReplacingOccurrencesOfString:@"\r" withString:@&quo ...