动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > JSP技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ JSP技巧 ]的信息

本月文章推荐
.Servlets和JSP Pages最佳实践.
.如何在Jsp中使用JDBC来联结MySql.
.JSP/Servlet应用程序优化八法.
.JSP应用语法详解大全 (3).
.新手看招:JSP中表单数据存储的通.
.基于JDBC的数据库连接池技术研究.
.用Request对象防止JSP缓存机制.
.JSP中读文件和写文件的例子.
.无边框窗口代码详解.
.解决tomcat启动时8080被占用的常.
.用按钮调用jsp代码怎么写?.
.JS+JSP+JAVABEAN树型列表的实现.
.可以使用多个jsp定制标签在JSP中.
.提升JSP页面响应速度的七大秘籍绝.
.高效的jsp分页查询.
.JSP实现论坛树型结构的具体算法.
.JSP中可能会碰到的问题解答.
.jsp连接数据库oracle.
.java/jsp中 中文问题详解.
.用定制标签库和配置文件实现对JS.

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

发表日期:2007-3-24 |


这篇文章讲的不错~把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文件如xerces.jar,jaxp.jar的支持。如果在使用中出现以下错误:
java.lang.NoSuchMethodError

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

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

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

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


下面是操作XML文件的Bean: XmlBean.java

package jdom.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) {
  this.bookname = bookname;
 }

 public void setauthor(String author) {
  this.author = author;
 }

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

 public void setprice(String price) {
  this.price = price;
 }

 public void setpubdate(String pubdate) {
  this.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 = doc.getRootElement(); // 得到根元素
   List books = root.getChildren(); // 得到根元素所有子元素的集合
   Element book = null;
   XmlBean xml = null;
   for (int i = 0; i < books.size(); i++) {
    xml = new XmlBean();
    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 (Exception e) {
   System.err.println(e + "error");
  } finally {
   try {
    fi.close();
   } catch (Exception e) {
    e.printStackTrace();
   }
  }
  return xmlVector;
 }

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

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

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

下面是操作的jsp文件: test.jsp
<%@ page contentType="text/html;charset=GBK"%>
<%@ page language="java" import="java.util.*,jdom.test.*"%>
<html>
<head>
<title>读取XML文件资料</title>
</head>
<body>
<h3 align="center">JDOM操作XML文件</h3>
<p align="center">读取XML文件中的所有资料</p>
<center>
<table border="1" cellpadding="0" cellspacing="1"
 style="border-collapse: collapse" width="80%" id="AutoNumber1">
 <tr>
  <td align="center" width="92">书名</td>
  <td align="center" width="92">作者</td>
  <td align="center" width="92">出版社</td>
  <td align="center" width="92">价格</td>
  <td align="center" width="92">出版日期</td>
  <td align="center" width="94">操作</td>
 </tr>
</table>
<%
  String path = application.getRealPath("/JDOM/MyXml.xml");
  XmlBean xml = new XmlBean();
  Vector xmlall = xml.LoadXML(path);
  for (int i = 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>");
    */
%>
<table border="1" cellpadding="0" cellspacing="1"
 style="border-collapse: collapse" width="80%" id="AutoNumber2">
 <tr>
  <td align="center" width="92"><%=xml.getbookname()%></td>
  <td align="center" width="92"><%=xml.getauthor()%></td>
  <td align="center" width="92"><%=xml.getpub()%></td>
  <td align="center" width="92"><%=xml.getprice()%></td>
  <td align="center" width="92"><%=xml.getpubdate()%></td>
  <td align="center" width="94"><a
   href="xmlaction.jsp?act=del&id=<%=i%>&path=<%=path%>">删除</a></td>
 </tr>
</table>
<%}%></center>
<form method="POST" action="xmlaction.jsp">
<p align="center"><input type="radio" value="add" checked name="act">添加资料
<input type="radio" value="edit" name="act">编辑资料 序 号:<select size="1"
 name="id">
 <%for (int i = 0; i < xmlall.size(); i++) {%>
 <option value="<%=i%>">第<%=i + 1%>条</option>
 <%}%>
</select><br>
书 名:<input type="text" name="bookname" size="20"><br>
作 者:<input type="text" name="author" size="20"><br>
出版社:<input type="text" name="pub" size="20"><br>
价 格:<input type="text" name="price" size="20"><br>
日 期:<input type="text" name="pubdate" size="20"></p>
<input type="hidden" name="path" value="<%=path%>">
<p align="center"><input type="submit" value="提交" name="B1"><input
 type="reset" value="重置" name="B2"></p>
</form>
</body>
</html>

下面是处理上一文件提交的jsp文件: xmlation.jsp
<%@ page contentType="text/html;charset=GBK"%>
<%@ page language="java" import="jdom.test.*"%>
<%if (request.getParameter("act") != null
    && request.getParameter("act").equals("add")) {
   XmlBean.AddXML(request);
   out.println("<p align='center'><br><br>添加成功<br><br><a href='test.jsp'>返回</a>");
  } else if (request.getParameter("act") != null
    && request.getParameter("act").equals("del")) {
   XmlBean.DelXML(request);
   out.println("<p align='center'><br><br>删除成功<br><br><a href='test.jsp'>返回</a>");
  } else if (request.getParameter("act") != null
    && request.getParameter("act").equals("edit")) {
   XmlBean.EditXML(request);
   out.println("<p align='center'><br><br>修改成功<br><br><a href='test.jsp'>返回</a>");
  } else {
   out.print("<p align='center'><br><br>非法操作<br><br><a href='test.jsp'>返回</a>");
  }
%>
/===============================正文结束========================================/
备注:
1,XmlBean.java 文件里法老注名文字为黄色的部分,是修改的地方,紫色引掉的部分是原程序的写法!
2,MyXml.xml 文件的默认编码法老改成了 encoding="utf-8" 的原因是:在weblogic 8下面解析GBK或者GB2312的时候总是异常,tomcat是好的,可能是weblogic自己默认的xml解析器不支持GBK吧,这个问题一直没搞好~如果哪位高手晓得解决方法,请回复此贴告诉我~~谢谢大家!

上一篇:jsp 内嵌网页内容--iframe 人气:5924
下一篇:jsp插入mysql数据库后乱码的解决办法 人气:6943
浏览全部JDOM的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-9-4 LPLY CMS 网站管理系统 v5.0
2008-9-4 缤纷互动视频交友 v3.01.902
2008-9-4 ADN视频收藏专家 v3.0 bulid 080
2008-9-4 天空网络电影系统SKYUC v2.5.6 简
2008-9-4 Web Wiz Rich Text Editor(文本编
2008-9-4 幻影动漫网视频系统(Ppdong) v1.
2008-9-4 乐维电脑在线DIY配置系统
2008-9-4 老樊文章管理系统SQL版
2008-9-4 ASP.NET 2.53 缩略图水印组件源码
2008-8-23 Mini WinMount V0.4
2008-8-23 Vista优化大师3.11正式版
2008-8-23 Wine 1.13
2008-8-23 KlipFolio 5.0 Build 5899-80
2008-8-23 Windows Sysinternals Desktops
2008-8-23 OneTap Movies1.2破解版
2008-8-23 AnnotaterPDF阅读1.1.503 破解版
2008-8-23 SoundMeter分贝测量仪 v1.0汉化破
2008-8-23 iDrum音乐节拍1.0破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | Html转换js | js/vbs加密 | md5加密 | 进制转换
实用工具:汉字翻译拼音 | 符号对照表 | 个税计算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵