声明:类容为学习传智播客方立勋教学视频,总结。
一:SAX采用事件处理方式解析XML文档:
解析器
和
事件处理器(有多个处理器)
a:解析器可以使用JAXP的API创建,创建出SAX解析器后,就可以指定解析器去解析某个文档了。
b:解析器只要解析到xml文档的一个组成部分,就会调用时间处理器的一个方法,同时把当前解析到的内容作为方法的参数传递给事件处理器。
得到解析器是模版代码:
// 获取sax解析工厂
SAXParserFactory factory = SAXParserFactory.newInstance();
// 获取sax解析器
SAXParser sp = factory.newSAXParser();
// 获取sax读取器
XMLReader reader = sp.getXMLReader();
// 设置内容处理器
reader.setContentHandler(new TagValue());
// 读取xml内容
reader.parse("src/dom.xml");
我们的主要工作就是写事件处理器。
有两种方式:
a:实现ContentHandler接口
b:继承DefaultHandler类,覆盖我们需要的方法。
二:dom4j解析xml文档
模版开始代码:
@Test
public void read() throws DocumentException{
SAXReader reader = new SAXReader();
Document doc = reader.read(new File("src/Book.xml"));
Element root = doc.getRootElement();
Element book = (Element) root.elements().get(1);
String value = book.element("书名").getText();
System.out.println(value);
}
写回文档的代码:
XMLWriter writer = new XMLWriter(new FileWriter("src/Book.xml"));
writer.write(doc);
writer.close();
dom4j有一个提取根标签的方法,很不错。
官方的说明文档很详细,基本一看就会了。就不在赘述了。
实例:
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.junit.BeforeClass;
import org.junit.Test;
import org.xml.sax.Attributes;
import org.xml.sax.ContentHandler;
import org.xml.sax.Locator;
import org.xml.sax.SAXException;
import org.xml.sax.XMLReader;
import org.xml.sax.helpers.DefaultHandler;
/**
* sax解析xml文档
*
* @author forlab
* @version 2012-12-19
*/
public class Sax {
public static void main(String[] args) {
try {
ReadXml();
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
@BeforeClass
public static void setUpBeforeClass() throws Exception {
}
public static void ReadXml() throws ParserConfigurationException, SAXException,
IOException {
// 获取sax解析工厂
SAXParserFactory factory = SAXParserFactory.newInstance();
// 获取sax解析器
SAXParser sp = factory.newSAXParser();
// 获取sax读取器
XMLReader reader = sp.getXMLReader();
// 设置内容处理器
BeanListHandler handler = new BeanListHandler();
reader.setContentHandler(handler);
// 读取xml内容
reader.parse("src/dom.xml");
List list = handler.getBooks();
}
}
class ListHander implements ContentHandler {
@Override
public void setDocumentLocator(Locator locator) {
// TODO Auto-generated method stub
}
@Override
public void startDocument() throws SAXException {
// TODO Auto-generated method stub
}
@Override
public void endDocument() throws SAXException {
// TODO Auto-generated method stub
}
@Override
public void startPrefixMapping(String prefix, String uri)
throws SAXException {
// TODO Auto-generated method stub
}
@Override
public void endPrefixMapping(String prefix) throws SAXException {
// TODO Auto-generated method stub
}
@Override
public void startElement(String uri, String localName, String qName,
Attributes atts) throws SAXException {
System.out.println("<"+qName+">");
//获取元素节点的属性值
for(int i=0;atts!=null && i<atts.getLength();i++){
String attName = atts.getQName(i);
String attValue = atts.getValue(i);
System.out.println(attName+"="+attValue);
}
}
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
System.out.println("<"+qName+">");
}
@Override
public void characters(char[] ch, int start, int length)
throws SAXException {
// TODO Auto-generated method stub
System.out.println(new String(ch, start, length));
}
@Override
public void ignorableWhitespace(char[] ch, int start, int length)
throws SAXException {
// TODO Auto-generated method stub
}
@Override
public void processingInstruction(String target, String data)
throws SAXException {
// TODO Auto-generated method stub
}
@Override
public void skippedEntity(String name) throws SAXException {
// TODO Auto-generated method stub
}
}
//继承类代码实现更容易
class TagValue extends DefaultHandler {
private String currentName;
private int needNum = 1;
private int currentNum;
@Override
public void startElement(String uri, String localName, String qName,
Attributes atts) throws SAXException {
// TODO Auto-generated method stub
currentName = qName;
if(currentName.equals("作者")){
currentNum++;
}
}
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
// TODO Auto-generated method stub
currentName = null;
}
@Override
public void characters(char[] ch, int start, int length)
throws SAXException {
// TODO Auto-generated method stub
if ("作者".equals(currentName) && currentNum == needNum ) {
System.out.println(new String(ch, start, length));
}
}
}
class BeanListHandler extends DefaultHandler{
private List list = new ArrayList();
private String currentTag;
private Book book;
@Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
currentTag = qName;
if("书".equals(currentTag)){
book = new Book();
}
}
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
if("书".equals(qName)){list.add(book);
book = null;
}
currentTag = null;
}
@Override
public void characters(char[] ch, int start, int length)
throws SAXException {
System.out.println("内容="+new String(ch,start,length));
if("书名".equals(currentTag)){
String value = new String(ch,start,length);
book.setName(value);
}
if("作者".equals(currentTag)){
String value = new String(ch,start,length);
book.setAuthor(value);
}
if("售价".equals(currentTag)){
String value = new String(ch,start,length);
book.setPrice(value);
}
}
public List getBooks(){
return list;
}
}
import java.io.File;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
import org.junit.BeforeClass;
import org.junit.Test;
/**
* @author forlab
* @version 2012-12-19
*/
public class Dom4j {
@BeforeClass
public static void setUpBeforeClass() throws Exception {
}
/**
* 利用xpath技术,查找dom.xml中name属性值为forlab的元素
* @throws DocumentException
*/
@Test
public void valid() throws DocumentException{
String username = "forlab";
SAXReader reader = new SAXReader();
Document document = reader.read(new File("src/dom.xml"));
Node node = document.selectSingleNode("//作者[@name='"+username+"']");
if(node==null){
System.out.println("用户名或者密码错误!");
}else{
System.out.println("恭喜登陆成功!");
}
}
}
相关资料:http://www.blogjava.net/junglesong/archive/2008/02/21/181196.html
分享到:
相关推荐
Java使用sax、dom、dom4j解析xml文档的代码,包含dom4j的jar包。
用DOM SAX JDom dom4j 对xml文档解析实例 在学习孙鑫老师视频教程,自己照着敲的源码,希望对大家有帮助
通过SAX和DOM的结合解析xml文档,实现既可以高速解析大文档,又可以实现对xml文档的简单操作
一个项目同时用dom解析和sax解析xml文件貌似会报错,项目框架建一直是用sax和dom4j解析xml文件的。当我用dom解析xml文件。导入包后就报错识别不了xml文件的编码格式。于是做了一个sax解析xml文件的实例
项目下包含dom4j的包 是里用dom4j的sax解析方式 sax解析打文件比dom速度快,该项目为测试项目
java学习笔记——使用DOM解析XML和使用SAX解析XML
DOM和SAX解析XML文档
dom4j下sax解析xml文件 sax解析大文件比dom更快 更节省内存,xml测试文件在src下,可直接运行应用jar包在lib下,无需导入
dom,dom4j,sax解析xml 文件经典实例,内置详细注解
读取和解析xml文件
对于xml&dom&sax&dom4j 文件解析的代码总结
Android 中利用SAX ,Dom,pull解析 XML 文件代码 每种方式都介绍了代码,具体的文档在个人博客: http://blog.csdn.net/blueskydyliu/article/details/7055311 中介绍了。
与利用DOM、SAX、JAXP机制来解析xml相比,DOM4J 表现更优秀,具有性能优异、功能强大和极端易用使用的特点,只要懂得DOM基本概念,就可以通过dom4j的api文档来解析xml。dom4j是一套开源的api。实际项目中,往往选择...
用四种方法实现了对xml文件的解析,对学习xml有很大帮助
Dom4j是一个开源的Java XML 解析处理工具,用来读写XML文件,它应用于Java平台,采用了Java集合框架并完全支持DOM, SAX和JAXP。具有性能优异、功能强大和极易使用的特点。可以作为解析XML文档析首先API。本文讲述了...
4种最主流、最全面、最详细的生成和解析xml的4种方式,包括Dom,Dom4j,Sax,JDom,读懂了绝对好用xml,非常好的入门项目,而且精心排版,逻辑清晰
XML_StuGradeExam_domXML解析技术之dom、Sax、dom4j技术演习以及Schema XML文档约束##XML解析开发包Jaxp(sun)Jdomdom4j####ExamExam是一个使用Xml持久化保存数据的xml数据库,该项目是演练dom解析XML技术很好的一个...
dom4j基础入门文档,与 W3C DOM API 相比,使用 dom4j 所包含的解析器的好处是 dom4j 拥有本地的 XPath 支持。
JAVA 解析XML和生成XML文档源码。比较全 1.DOM生成和解析XML文档 2.SAX生成和解析XML文档 3.DOM4J生成和解析XML文档 4.JDOM生成和解析XML
现在流行的几种解析xml的方法,都做了相应的创建和解析XML的demo,虽然有点简单,但是和新手入门