`
xsuo
  • 浏览: 123411 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

Java + XML = JDOM

阅读更多
Java+XML=JDOM!
这就是JDOM设计者的目标。如果你曾经使用过烦人的SAX或是DOM来处理XML,你就会知道为 什么要有JDOM或者是JAXB。在今年(2002)的JavaOne会议上JDOM的主要创始人JasonHunter有一篇精彩的演讲介绍了 JDOM技术,题目就是JDOMMakesXMLEasy。
获得并安装JDOM
http://jdom.org可 以下载JDOM的最新版本。以JDOMbeta8的2进制版本为例。下载后解压缩,JDOM的jar文件就是build目录下的文件jdom.jar, 将之加入类路径。另外JDOM还需要lib目录下那些jar文件如xerces.jar,jaxp.jar的支持。如果在使用中出现以下错误:
java.lang.NoSuchMethodError

java.lang.NoClassDefFoundError:org/xml/sax/SAXNotRecognizedException
你需要保证xerces.jar文件在CLASSPATH中位于其他XML类,如JAXP或Crimson之前,这些类文件,包括以前老版本的xerces,可能不支持SAX2.0或DOMLevel2。于是导致了上面的错误。

一个简单的例子
JDOM的处理方式有些类似于DOM,但它主要是用SAX实现的,你不必担心处理速度和内存的问题。另外,JDOM中几乎没有接口,的类全部是实实在在的类,没有类工厂类的。

下面是实例用的XML文件:

<?xmlversion="1.0"encoding="GBK"?>
<书库>
<书>
<书名>Java编程入门</书名>
<作者>张三</作者>
<出版社>电子出版社</出版社>
<价格>35.0</价格>
<出版日期>2002-10-07</出版日期>
</书>
<书>
<书名>XML在Java中的应用</书名>
<作者>李四</作者>
<出版社>希望出版社</出版社>
<价格>92.0</价格>
<出版日期>2002-10-07</出版日期>
</书>
</书库>

下面是操作XML文件的Bean:
packagexml;
/**
*XML的读写操作Bean
*/
importjava.io.*;
importjava.util.*;
importorg.jdom.*;
importorg.jdom.output.*;
importorg.jdom.input.*;
importjavax.servlet.*;
importjavax.servlet.http.*;
publicclassXmlBean{
privateStringbookname,author,pub,price,pubdate;
publicStringgetbookname(){returnbookname;}
publicStringgetauthor(){returnauthor;}
publicStringgetpub(){returnpub;}
publicStringgetprice(){returnprice;}
publicStringgetpubdate(){returnpubdate;}
publicvoidsetbookname(Stringbookname){this.bookname=bookname;}
publicvoidsetauthor(Stringauthor){this.author=author;}
publicvoidsetpub(Stringpub){this.pub=pub;}
publicvoidsetprice(Stringprice){this.price=price;}
publicvoidsetpubdate(Stringpubdate){this.pubdate=pubdate;}
publicXmlBean(){}
/**
*读取XML文件所有信息
*/
publicVectorLoadXML(Stringpath)throwsException{
VectorxmlVector=null;
FileInputStreamfi=null;
try{
fi=newFileInputStream(path);
xmlVector=newVector();
SAXBuildersb=newSAXBuilder();
Documentdoc=sb.build(fi);
Elementroot=doc.getRootElement();//得到根元素
Listbooks=root.getChildren();//得到根元素所有子元素的集合
Elementbook=null;
XmlBeanxml=null;
for(inti=0;i<books.size();i++){
xml=newXmlBean();
book=(Element)books.get(i);//得到第一本书元素
xml.setbookname(book.getChild("书名").getText());
xml.setauthor(book.getChild("作者").getText());
xml.setpub(book.getChild("出版社").getText());
xml.setprice(book.getChild("价格").getText());
xml.setpubdate(book.getChild("出版日期").getText());
xmlVector.add(xml);
}
}
catch(Exceptione){
System.err.println(e+"error");
}
finally{
try{
fi.close();
}
catch(Exceptione){
e.printStackTrace();
}
}
returnxmlVector;
}
/**
*删除XML文件指定信息
*/
publicstaticvoidDelXML(HttpServletRequestrequest)throwsException{
FileInputStreamfi=null;
FileOutputStreamfo=null;
try{
Stringpath=request.getParameter("path");
intxmlid=Integer.parseInt(request.getParameter("id"));
fi=newFileInputStream(path);
SAXBuildersb=newSAXBuilder();
Documentdoc=sb.build(fi);
Elementroot=doc.getRootElement();//得到根元素
Listbooks=root.getChildren();//得到根元素所有子元素的集合
books.remove(xmlid);//删除指定位置的子元素
Stringindent="";
booleannewLines=true;
XMLOutputteroutp=newXMLOutputter(indent,newLines,"GBK");
fo=newFileOutputStream(path);
outp.output(doc,fo);
}
catch(Exceptione){
System.err.println(e+"error");
}
finally{
try{
fi.close();
fo.close();
}
catch(Exceptione){
e.printStackTrace();
}
}
}
/**
*添加XML文件指定信息
*/
publicstaticvoidAddXML(HttpServletRequestrequest)throwsException{
FileInputStreamfi=null;
FileOutputStreamfo=null;
try{
Stringpath=request.getParameter("path");
fi=newFileInputStream(path);
SAXBuildersb=newSAXBuilder();
Documentdoc=sb.build(fi);
Elementroot=doc.getRootElement();//得到根元素
Listbooks=root.getChildren();//得到根元素所有子元素的集合
Stringbookname=request.getParameter("bookname");
Stringauthor=request.getParameter("author");
Stringprice=request.getParameter("price");
Stringpub=request.getParameter("pub");
Stringpubdate=request.getParameter("pubdate");
Textnewtext;
Elementnewbook=newElement("书");
Elementnewname=newElement("书名");
newname.setText(bookname);
newbook.addContent(newname);
Elementnewauthor=newElement("作者");
newauthor.setText(author);
newbook.addContent(newauthor);
Elementnewpub=newElement("出版社");
newpub.setText(pub);
newbook.addContent(newpub);
Elementnewprice=newElement("价格");
newprice.setText(price);
newbook.addContent(newprice);
Elementnewdate=newElement("出版日期");
newdate.setText(pubdate);
newbook.addContent(newdate);
books.add(newbook);//增加子元素
Stringindent="";
booleannewLines=true;
XMLOutputteroutp=newXMLOutputter(indent,newLines,"GBK");
fo=newFileOutputStream(path);
outp.output(doc,fo);
}
catch(Exceptione){
System.err.println(e+"error");
}
finally{
try{
fi.close();
fo.close();
}
catch(Exceptione){
e.printStackTrace();
}
}
}
/**
*修改XML文件指定信息
*/
publicstaticvoidEditXML(HttpServletRequestrequest)throwsException{
FileInputStreamfi=null;
FileOutputStreamfo=null;
try{
Stringpath=request.getParameter("path");
intxmlid=Integer.parseInt(request.getParameter("id"));
fi=newFileInputStream(path);
SAXBuildersb=newSAXBuilder();
Documentdoc=sb.build(fi);
Elementroot=doc.getRootElement();//得到根元素
Listbooks=root.getChildren();//得到根元素所有子元素的集合
Elementbook=(Element)books.get(xmlid);
Stringbookname=request.getParameter("bookname");
Stringauthor=request.getParameter("author");
Stringprice=request.getParameter("price");
Stringpub=request.getParameter("pub");
Stringpubdate=request.getParameter("pubdate");
Textnewtext;
Elementnewname=book.getChild("书名");
newname.setText(bookname);//修改书名为新的书名
Elementnewauthor=book.getChild("作者");
newauthor.setText(author);
Elementnewpub=book.getChild("出版社");
newpub.setText(pub);
Elementnewprice=book.getChild("价格");
newprice.setText(price);
Elementnewdate=book.getChild("出版日期");
newdate.setText(pubdate);
//books.set(xmlid,book);//修改子元素
Stringindent="";
booleannewLines=true;
XMLOutputteroutp=newXMLOutputter(indent,newLines,"GBK");
fo=newFileOutputStream(path);
outp.output(doc,fo);
}
catch(Exceptione){
System.err.println(e+"error");
}
finally{
try{
fi.close();
fo.close();
}
catch(Exceptione){
e.printStackTrace();
}
}
}
}

下面是操作的jsp文件:
<%@pagecontentType="text/html;charset=GBK"%>
<%@pagelanguage="java"import="java.util.*,xml.*"%>
<html>
<head>
<title>读取XML文件资料</title>
</head>
<body>
<h3align="center">JDOM操作XML文件</h3>
<palign="center">读取XML文件中的所有资料</p>
<center>
<tableborder="1"cellpadding="0"cellspacing="1"style="border-collapse:collapse"width="80%"id="AutoNumber1">
<tr>
<tdalign="center"width="92">书名</td>
<tdalign="center"width="92">作者</td>
<tdalign="center"width="92">出版社</td>
<tdalign="center"width="92">价格</td>
<tdalign="center"width="92">出版日期</td>
<tdalign="center"width="94">操作</td>
</tr>
</table>
<%
Stringpath=application.getRealPath("/test/xml/")+"testC.xml";
XmlBeanxml=newXmlBean();
Vectorxmlall=xml.LoadXML(path);
for(inti=0;i<xmlall.size();i++){
xml=(XmlBean)xmlall.elementAt(i);
/**out.println("书名:"+xml.getbookname()+"<br>");
out.println("作者:"+xml.getauthor()+"<br>");
out.println("出版社:"+xml.getpub()+"<br>");
out.println("价格:"+xml.getprice()+"<br>");
out.println("出版日期:"+xml.getpubdate()+"<br><br>");
*/
%>
<tableborder="1"cellpadding="0"cellspacing="1"style="border-collapse:collapse"width="80%"id="AutoNumber2">
<tr>
<tdalign="center"width="92"><%=xml.getbookname()%></td>
<tdalign="center"width="92"><%=xml.getauthor()%></td>
<tdalign="center"width="92"><%=xml.getpub()%></td>
<tdalign="center"width="92"><%=xml.getprice()%></td>
<tdalign="center"width="92"><%=xml.getpubdate()%></td>
< tdalign="center"width="94"><ahref="xmlok.jsp?act=del&id=< %=i%>&path=<%=path%>">删除</a></td>
</tr>
</table>
<%}%>
</center>
<formmethod="POST"action="xmlok.jsp">
<palign="center">
<inputtype="radio"value="add"checkedname="act">添加资料<inputtype="radio"value="edit"name="act">编辑资料
序号:<selectsize="1"name="id">
<%for(inti=0;i<xmlall.size();i++){%>
<optionvalue="<%=i%>">第<%=i+1%>条</option>
<%}%>
</select><br>
书名:<inputtype="text"name="bookname"size="20"><br>
作者:<inputtype="text"name="author"size="20"><br>
出版社:<inputtype="text"name="pub"size="20"><br>
价格:<inputtype="text"name="price"size="20"><br>
日期:<inputtype="text"name="pubdate"size="20"></p>
<inputtype="hidden"name="path"value="<%=path%>">
<palign="center"><inputtype="submit"value="提交"name="B1"><inputtype="reset"value="重置"name="B2"></p>
</form>
</body>
</html>

下面是处理上一文件提交的jsp文件:
<%@pagecontentType="text/html;charset=GBK"%>
<%@pagelanguage="java"import="xml.*"%>
<%if(request.getParameter("act")!=null&&request.getParameter("act").equals("add")){
XmlBean.AddXML(request);
out.println("<palign='center'><br><br>添加成功<br><br><ahref=''>返回</a>");
}
elseif(request.getParameter("act")!=null&&request.getParameter("act").equals("del")){
XmlBean.DelXML(request);
out.println("<palign='center'><br><br>删除成功<br><br><ahref=''>返回</a>");
}
elseif(request.getParameter("act")!=null&&request.getParameter("act").equals("edit")){
XmlBean.EditXML(request);
out.println("<palign='center'><br><br>修改成功<br><br><ahref=''>返回</a>");
}
else{out.print("<palign='center'><br><br>非法操作<br><br><ahref=''>返回</a>");}

分享到:
评论

相关推荐

    java读取XML(JDOM)

    Java读取XML文件是开发过程中常见的任务,JDOM是一个用于处理XML文档的Java库,它提供了方便、高效的方式来创建和操作XML数据。本篇将详细讲解如何使用JDOM来读取XML文件,以及相关的源码解析。 首先,我们需要了解...

    Spring+iBatis+JDom递归生成XML树

    JDom是Java的一个库,用于处理XML文档。它提供了一种简单且高性能的方式来创建、修改和读取XML内容。在本项目中,JDom用于构建XML树结构。通过递归算法,我们可以遍历数据库中获取的数据,并用JDom创建出对应的XML...

    Java生成xml(jdom)

    本教程将深入探讨如何使用JDOM库在Java中生成XML文档,并且重点介绍如何处理中文字符。 JDOM(Java Document Object Model)是一个纯Java的API,用于读取、写入和操作XML文档。它提供了简单而直接的方式来创建和...

    java+xml联合编程简单例子

    4. **JDOM(Java Document Object Model)**:JDOM是一个纯Java的DOM实现,提供了对XML的更直接的处理,比标准DOM更易于使用,但性能稍逊。 5. **DOM4J**:DOM4J是另一个流行的Java XML库,它提供了丰富的功能,...

    Java+XML写的RSS阅读器

    Java提供了一些库,如JDOM、DOM4J和Java的内置DOM解析器,可以用来处理XML文档。解析器将XML内容转换为易于处理的对象结构,如RSS频道、条目、作者等。 2. **XML处理**:XML文档的解析通常涉及到DOM(Document ...

    java利用jdom读取xml文件

    Java语言在处理XML数据时,常常会用到各种解析库,其中之一便是JDOM。JDOM,全称为Java Document Object Model,是一种专为Java设计的XML处理API,它提供了对XML文档结构的完整映射,使得我们可以方便地创建、读取和...

    jdom-test-1.1.zip_Java Test_java 操作xml_jdom_jdom xml_xml java jd

    在Java中,处理XML文件有多种库,其中之一便是JDOM。本示例“jdom-test-1.1.zip”提供了使用JDOM库操作XML的详细教程。 JDOM,全称为Java Document Object Model,是一个专为Java设计的API,用于读写XML文档。它...

    java xml解析 jdom经典完整代码

    在Java中,有多种XML解析器,其中JDOM(Java Document Object Model)是一个流行的选择。JDOM提供了方便的API,可以直接映射XML文档到Java对象,从而简化XML操作。 XML(eXtensible Markup Language)是一种用于...

    java xml解析jdom类库

    用于xml解析,很好用的一个java类库

    spring+ibatis+jDom递归生成

    jDom是Java的一个XML处理库,它提供了DOM(文档对象模型)解析器,可以用于创建、修改和读取XML文档。jDom的优势在于其完全用Java实现,与JVM紧密集成,性能相对较好,并且提供了直观的API供开发者使用。 当我们...

    jdom 读取XML 文件

    JDOM是Java中一个用于处理XML文档的库,它提供了一种高效且方便的方式来创建、读取、修改XML文件。本篇文章将深入探讨如何使用JDOM来读取XML文件。 首先,我们需要了解JDOM的基本概念。JDOM通过构建一棵DOM...

    Structs2+Spring+hibernate+jdom+junit+读取excel+serve2005+oracle+mysql 架包

    标题中的"Structs2+Spring+hibernate+jdom+junit+读取excel+serve2005+oracle+mysql 架包"涉及到一系列在Java开发中常用的框架和技术,这是一套集成的开发环境,可以帮助开发者快速搭建企业级应用。下面将对这些技术...

    java jdom解析xml

    Java JDOM解析XML是Java开发中处理XML文档的一种方法,JDOM全称为Java Document Object Model,它是一个基于Java语言的API,用于创建、修改和读取XML文档。JDOM为XML处理提供了一种高效且方便的解决方案,尤其适用于...

    xml数据前后台解析:jdom与dom4j源码,程序可以跑

    本文将深入探讨XML数据在前后台解析的过程中,重点介绍两种主流的Java XML解析库——JDOM和DOM4J,并提供实际运行的程序示例。同时,我们还会讨论如何使用jQuery在前端解析XML并展示数据。 首先,让我们了解XML的...

    JAR包+sql+oracle+dwr+jdom+ibatis+struts2

    总结来说,这个项目可能是一个使用Struts2作为MVC框架,Oracle作为数据库,iBatis作为持久层,DWR实现异步通信,JDOM处理XML数据,而所有组件和依赖被打包成JAR文件的Java Web应用程序。这样的架构设计能够提供高效...

    JAVA_xml读写(jdom包)

    JDOM(Java Document Object Model)是一个纯Java的XML API,它提供了方便的方式来创建、修改和操作XML文档。本教程将详细介绍如何使用JDOM进行XML的读写操作。 首先,确保你已经将JDOM包导入到你的Java项目中。...

    JAVA操作XML\XML\Jdom使用指南 java教程 -113e博章.mht

    JAVA操作XML\XML\Jdom使用指南 java教程 -113e博章.mht

    java利用jdom解析xml文件

    Java中的JDOM库是用于解析XML文档的一种强大的工具。它提供了简单、高效的API来读取、修改和创建XML文件。本篇文章将深入探讨如何利用JDOM解析XML文件,以及在这个过程中涉及的关键知识点。 首先,我们需要了解XML...

    使用JDOM解析XML文件

    在Java编程中,JDOM(Java Document Object Model)是处理XML的一种库,它提供了方便的方式来创建、修改和读取XML文档。本篇文章将深入探讨如何使用JDOM解析XML文件。 首先,我们需要理解JDOM的基本结构。JDOM通过...

    java用jdom解析xml到txt

    Java中的JDOM库是一个强大的工具,用于处理XML文档。它提供了简单、高效的API来创建、修改和读取XML数据。本篇文章将详细讲解如何使用JDOM解析XML文档,并将其内容导出到TXT文本文件。 首先,我们需要理解XML...

Global site tag (gtag.js) - Google Analytics