JavaWeb-----用Java程序操作XML①
Posted 袁阳的csdn博客
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaWeb-----用Java程序操作XML①相关的知识,希望对你有一定的参考价值。
XML的诞生原本是用来对数据进行更好更快的存储。XML的雏形用于航空工业,到后来慢慢进行简化,形成了我们现在常用的形式,由于XML能够很好的表现数据的层次结构(在java中,一般集合也就能表现出一种平面结构),在以前很多人都认为xml会成为一种卓越的语言,甚至提到Java等编程语言。后来证明:XML不仅没有取代java,反而成为java很好的帮手。闲话不扯了。进入正题。。。
XML是用来保存数据的,对于数据的操作,就是增删改查。
获取代表XML文档的Document对象
java程序在读取XML一般有两种方式。一:DOM形式读取。特点是:结构清晰,容易使用,但是占用内存较大二:SAX。使用流式读取XML。特点:占用内存小,但是不能全部获取所有的节点,不方便操作。程序开发一般使用DOM模型来解析xml。在J2SE包中后几个是关于采用DOM方式解析xml的。 Document对象代表xml文件。所有的节点用Node代表。通过Node可以获取节点的某些数据。Element对象代表xml中的单个元素。可以通过该对象获取元素的数据,比如说:属性等。 获取document对象需要通过Java提供的DocumentBuilderFactory工厂类获取DocumentBuilder。注意:DocumentBuilderFactory的构造函数私有,需要使用newInstance方法获取该工厂实例。通过工厂实例获取解析器实例DocumentBuoilder。 然后使用解析器实例获取代表Xml文档的Document对象。示例代码:public static Document getDocument() throws Exception
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder=factory.newDocumentBuilder();
Document document=builder.parse(new File("src/student.xml"));
return document;
使用XML增加数据
增加数据的算法大致是:先通过Document实例创造出你要添加的节点。将创建好节点挂靠在父节点下。可以指定增加节点的位置。 1.不指定位置添加节点。示例代码:public void add()
DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
try
DocumentBuilder builder=factory.newDocumentBuilder();
Document document=builder.parse(new File("src/book.xml"));
Element e=document.createElement("售价");
e.setTextContent("59.00");
Node book=document.getElementsByTagName("书").item(0);
book.appendChild(e);
TransformerFactory f= TransformerFactory.newInstance();
Transformer transfomer=f.newTransformer();
transfomer.transform(new DOMSource(document), new StreamResult(new File("src/book.xml")));
catch (Exception e)
// TODO Auto-generated catch block
e.printStackTrace();
对应的xml文件是:
<?xml version="1.0" encoding="utf-8" standalone="no"?><书架>
<书 name="yyyy">
<售价>109</售价>
<售价>50</售价><书名>Java就业培训教程</书名>
<作者>ligang</作者>
<售价>59.00</售价>
</书>
</书架>
2在指定位置添加节点。思路是:创建节点,找到插入位置后面的一个节点,通过父节点的insertbefore挂靠节点:示例代码:
public void add2()
DocumentBuilderFactory factory =DocumentBuilderFactory.newInstance();
try
DocumentBuilder builder=factory.newDocumentBuilder();
Document document=builder.parse(new File("src/book.xml"));
Element e=document.createElement("售价");
e.setTextContent("50");
Node node=document.getElementsByTagName("书").item(0);
node.insertBefore(e, document.getElementsByTagName("书名").item(0));
TransformerFactory f= TransformerFactory.newInstance();
Transformer t=f.newTransformer();
t.transform(new DOMSource(document),new StreamResult(new File("src/book.xml")));
catch (Exception e)
// TODO Auto-generated catch block
e.printStackTrace();
查找节点: 通过Document对象可以获取某个指定的节点。通过标签名获取含有该标签名的所有节点结合(NodeList)。便利集合,找到你要查找的节点或者数据;示例代码:
public static Student findStudentFormName(String name)
Student s =new Student();
try
Document document =Dao.getDocument();
NodeList node1=document.getElementsByTagName("姓名");
for(int i=0;i<node1.getLength();i++)
if(node1.item(i).getTextContent().equals(name))
Node student=node1.item(i).getParentNode();
if(student.getNodeType()==Node.ELEMENT_NODE)
NodeList list=student.getChildNodes();
s.setName(name);
for(int j=0;j<list.getLength();j++)
Node n = list.item(j);
String context = n.getTextContent();
if(n.getNodeName().equals("学号"))
s.setId(Integer.valueOf(context));
else if(n.getNodeName().equals("性别"))
s.setSex(context);
else if(n.getNodeName().equals("操作系统"))
s.setGradeOS(Double.valueOf(context));
else if(n.getNodeName().equals("c语言"))
s.setGradeC(Double.valueOf(context));
catch(Exception e)
e.printStackTrace();
return s;
xml文件是:
<?xml version="1.0" encoding="UTF-8" standalone="no"?><信息>
<学生><c语言>78.0</c语言><操作系统>89.0</操作系统><性别>男</性别><姓名>袁阳</姓名><学号>123456</学号></学生></信息>
对应的JavaBean可以自己写。
接下来会通过java语言来删除数据和利用xml做的信息管理系统。以上是关于JavaWeb-----用Java程序操作XML①的主要内容,如果未能解决你的问题,请参考以下文章