特色栏目

ASP源码

PHP源码

.NET源码

JSP源码

游戏频道
专题合集
关闭菜单
首页> JSP教程> JDOM操作XML文件(法老修正版)

JDOM操作XML文件(法老修正版)

时间:2009-07-03 16:53:42 作者:互联网

这篇文章讲的不错~把JDOM的基本操作实例化了,不过由于当时的作者用的JDOM版本还比较陈旧,所以部分代码会编译出错!支持中文也不好!所以,法老在原作者的基础上对程序做了修改!休正了编译出错以及中文乱码的问题。发表出来,供大家学习和使用。
测试环境:jdom1.0,weblogic 8.1sp2,tomcat 5.0,IE 6。0
/==================================正文开始=======================================/
Java + XML = JDOM !
这就是JDOM设计者的目标。如果你曾经使用过烦人的SAX或是DOM来处理XML,你就会知道为什么要有JDOM或者是JAXB。在今年(2002)的JavaOne会议上JDOM的主要创始人Jason Hunter有一篇精彩的演讲介绍了JDOM技术,题目就是JDOM Makes XML Easy。
获得并安装JDOM
http://jdom.org可以下载JDOM的最新版本。以JDOM 1.0的2进制版本为例。下载后解压缩,JDOM的jar文件就是build目录下的文件jdom.jar,将之加入类路径。另外JDOM还需要lib目录下那些jar文件如xe***s.jar,jaxp.jar的支持。如果在使用中出现以下错误:
ja***lang.NoSuchMethodError

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

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

下面是实例用的XML文件: My***.xml


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


下面是操作XML文件的Bean: Xm***an.java

package jd***test;

/**
 * XML的读写操作Bean
 */
import java.io.*;
import java.util.*;
import org.jdom.*;
import org.jdom.output.*;
import org.jdom.input.*;
import javax.servlet.*;
import javax.servlet.http.*;

public class XmlBean {
 private String bookname, author, pub, price, pubdate;

 public String getbookname() {
  return bookname;
 }

 public String getauthor() {
  return author;
 }

 public String getpub() {
  return pub;
 }

 public String getprice() {
  return price;
 }

 public String getpubdate() {
  return pubdate;
 }

 public void setbookname(String bookname) {
  th***bookname = bookname;
 }

 public void setauthor(String author) {
  th***author = author;
 }

 public void setpub(String pub) {
  this.pub = pub;
 }

 public void setprice(String price) {
  th***price = price;
 }

 public void setpubdate(String pubdate) {
  th***pubdate = pubdate;
 }

 public XmlBean() {
 }

 /**
  * 读取XML文件所有信息
  */
 public Vector LoadXML(String path) throws Exception {
  Vector xmlVector = null;
  FileInputStream fi = null;
  try {
   fi = new FileInputStream(path);
   xmlVector = new Vector();
   SAXBuilder sb = new SAXBuilder();
   Document doc = sb.build(fi);
   Element root = do***etRootElement(); // 得到根元素
   List books = ro***getChildren(); // 得到根元素所有子元素的集合
   Element book = null;
   XmlBean xml = null;
   for (int i = 0; i < bo***.size(); i++) {
    xml = new XmlBean();
    book = (Element) bo***.get(i); // 得到第一本书元素
    xm***etbookname(bo***getChild("书名").getText());
    xm***etauthor(bo***getChild("作者").getText());
    xm***etpub(bo***getChild("出版社").getText());
    xm***etprice(bo***getChild("价格").getText());
    xm***etpubdate(bo***getChild("出版日期").getText());
    xm***ctor.add(xml);
   }
  } catch (Exception e) {
   Sy***m.err.println(e + "error");
  } finally {
   try {
    fi.close();
   } catch (Exception e) {
    e.***ntStackTrace();
   }
  }
  return xmlVector;
 }

 /**
  * 删除XML文件指定信息
  */
 public static void DelXML(HttpServletRequest request) throws Exception {
  FileInputStream fi = null;
  FileOutputStream fo = null;
  try {
   re***st.setCharacterEncoding("GBK");
   String path = re***st.getParameter("path");
   int xmlid = In***er.parseInt(re***st.getParameter("id"));
   fi = new FileInputStream(path);
   SAXBuilder sb = new SAXBuilder();
   Document doc = sb.build(fi);
   Element root = do***etRootElement(); // 得到根元素
   List books = ro***getChildren(); // 得到根元素所有子元素的集合
   bo***.remove(xmlid);// 删除指定位置的子元素
//   String indent = " ";
//   boolean newLines = true;
//   XMLOutputter outp = new XMLOutputter(indent, newLines, "GBK");
      Format format = Fo***t.getPrettyFormat();
      fo***t.setIndent("  ");
      fo***t.setEncoding("utf-8");
      XMLOutputter outp = new XMLOutputter(format);
   fo = new FileOutputStream(path);
   ou***output(doc, fo);
  } catch (Exception e) {
   Sy***m.err.println(e + "error");
  } finally {
   try {
    fi.close();
    fo.close();
   } catch (Exception e) {
    e.***ntStackTrace();
   }
  }
 }

 /**
  * 添加XML文件指定信息
  */
 public static void AddXML(HttpServletRequest request) throws Exception {
  FileInputStream fi = null;
  FileOutputStream fo = null;
  try {
   re***st.setCharacterEncoding("GBK");
   String path = re***st.getParameter("path");
   fi = new FileInputStream(path);
   SAXBuilder sb = new SAXBuilder();
   Document doc = sb.build(fi);
   Element root = do***etRootElement(); // 得到根元素
   List books = ro***getChildren(); // 得到根元素所有子元素的集合
   String bookname = re***st.getParameter("bookname");
   String author = re***st.getParameter("author");
   String price = re***st.getParameter("price");
   String pub = re***st.getParameter("pub");
   String pubdate = re***st.getParameter("pubdate");
//   Text newtext;
   Element newbook = new Element("书");
   Element newname = new Element("书名");
   ne***me.setText(bookname);
   ne***ok.addContent(newname);
   Element newauthor = new Element("作者");
   ne***thor.setText(author);
   ne***ok.addContent(newauthor);
   Element newpub = new Element("出版社");
   ne***b.setText(pub);
   ne***ok.addContent(newpub);
   Element newprice = new Element("价格");
   ne***ice.setText(price);
   ne***ok.addContent(newprice);
   Element newdate = new Element("出版日期");
   ne***te.setText(pubdate);
   ne***ok.addContent(newdate);
   bo***.add(newbook);// 增加子元素
//   String indent = " ";
//   boolean newLines = true;
//   XMLOutputter outp = new XMLOutputter(indent, newLines, "GBK");
      Format format = Fo***t.getPrettyFormat();
      fo***t.setIndent("  ");
      fo***t.setEncoding("utf-8");
      XMLOutputter outp = new XMLOutputter(format);
   fo = new FileOutputStream(path);
   ou***output(doc, fo);
  } catch (Exception e) {
   Sy***m.err.println(e + "error");
  } finally {
   try {
    fi.close();
    fo.close();
   } catch (Exception e) {
    e.***ntStackTrace();
   }
  }
 }

 /**
  * 修改XML文件指定信息
  */
 public static void EditXML(HttpServletRequest request) throws Exception {
  FileInputStream fi = null;
  FileOutputStream fo = null;
  try {
   re***st.setCharacterEncoding("GBK");
   String path = re***st.getParameter("path");
   int xmlid = In***er.parseInt(re***st.getParameter("id"));
   fi = new FileInputStream(path);
   SAXBuilder sb = new SAXBuilder();
   Document doc = sb.build(fi);
   Element root = do***etRootElement(); // 得到根元素
   List books = ro***getChildren(); // 得到根元素所有子元素的集合
   Element book = (Element) bo***.get(xmlid);
   String bookname = re***st.getParameter("bookname");
   String author = re***st.getParameter("author");
   String price = re***st.getParameter("price");
   String pub = re***st.getParameter("pub");
   String pubdate = re***st.getParameter("pubdate");
//   Text newtext;
   Element newname = bo***getChild("书名");
   ne***me.setText(bookname);// 修改书名为新的书名
   Element newauthor = bo***getChild("作者");
   ne***thor.setText(author);
   Element newpub = bo***getChild("出版社");
   ne***b.setText(pub);
   Element newprice = bo***getChild("价格");
   ne***ice.setText(price);
   Element newdate = bo***getChild("出版日期");
   ne***te.setText(pubdate);
   // bo***.set(xmlid,book);//修改子元素
//   String indent = " ";
//   boolean newLines = true;
//   XMLOutputter outp = new XMLOutputter(indent, newLines, "GBK");
      Format format = Fo***t.getPrettyFormat();
      fo***t.setIndent("  ");
      fo***t.setEncoding("utf-8");
      XMLOutputter outp = new XMLOutputter(format);
   fo = new FileOutputStream(path);
   ou***output(doc, fo);
  } catch (Exception e) {
   Sy***m.err.println(e + "error");
  } finally {
   try {
    fi.close();
    fo.close();
   } catch (Exception e) {
    e.***ntStackTrace();
   }
  }
 }
}

下面是操作的jsp文件: test.jsp
<%@ page contentType="text/html;charset=GBK"%>
<%@ page language="java" import="java.util.*,jd***test.*"%>


读取XML文件资料


JDOM操作XML文件


读取XML文件中的所有资料



 style="border-collapse: collapse" width="80%" id="AutoNumber1">
 
 
 
 
 
 
 
 
书名作者出版社价格出版日期操作

<%
  String path = ap***cation.getRealPath("/JDOM/My***.xml");
  XmlBean xml = new XmlBean();
  Vector xmlall = xm***oadXML(path);
  for (int i = 0; i < xm***l.size(); i++) {
   xml = (XmlBean) xm***l.elementAt(i);
   /****t.println("书名:"+xm***etbookname()+"
");
    ou***rintln("作者:"+xm***etauthor()+"
");
    ou***rintln("出版社:"+xm***etpub()+"
");
    ou***rintln("价格:"+xm***etprice()+"
");
    ou***rintln("出版日期:"+xm***etpubdate()+"

");
    */
%>
 style="border-collapse: collapse" width="80%" id="AutoNumber2">
 
 
 
 
 
 
 
 
<%=xm***etbookname()%><%=xm***etauthor()%><%=xm***etpub()%><%=xm***etprice()%><%=xm***etpubdate()%>   href="xm***tion.jsp?act=del&id=<%=i%>&path=<%=path%>">删除

<%}%>

xm***tion.jsp">

添加资料
编辑资料 序 号:

书 名:

作 者:

出版社:

价 格:

日 期:



 type="reset" value="重置" name="B2">




下面是处理上一文件提交的jsp文件: xm***ion.jsp
<%@ page contentType="text/html;charset=GBK"%>
<%@ page language="java" import="jd***test.*"%>
<%if (re***st.getParameter("act") != null
    && re***st.getParameter("act").equals("add")) {
   Xm***an.AddXML(request);
   ou***rintln("



添加成功

返回");
  } else if (re***st.getParameter("act") != null
    && re***st.getParameter("act").equals("del")) {
   Xm***an.DelXML(request);
   ou***rintln("



删除成功

返回");
  } else if (re***st.getParameter("act") != null
    && re***st.getParameter("act").equals("edit")) {
   Xm***an.EditXML(request);
   ou***rintln("



修改成功

返回");
  } else {
   ou***rint("



非法操作

返回");
  }
%>
/===============================正文结束========================================/
备注:
1,Xm***an.java 文件里法老注名文字为黄色的部分,是修改的地方,紫色引掉的部分是原程序的写法!
2,My***.xml 文件的默认编码法老改成了 encoding="utf-8" 的原因是:在weblogic 8下面解析GBK或者GB2312的时候总是异常,tomcat是好的,可能是weblogic自己默认的xml解析器不支持GBK吧,这个问题一直没搞好~如果哪位高手晓得解决方法,请回复此贴告诉我~~谢谢大家!

相关文章 最新文章

相关应用

热门文章

猜你喜欢

返回顶部