为什么我输出的value都是null呢,跟老师一样的代码
输出:
SAX解析开始
=========开始遍历第1本书的内容=========
book元素的第1个属性名是:id---属性值是:1
节点名是:name-----节点值是:冰与火之歌
节点名是:author-----节点值是:乔治马丁
节点名是:year-----节点值是:2014
节点名是:price-----节点值是:89
===========结束遍历第1本书的内容===============
=========开始遍历第2本书的内容=========
book元素的第1个属性名是:id---属性值是:2
节点名是:name-----节点值是:安徒生童话
节点名是:year-----节点值是:2004
节点名是:price-----节点值是:77
节点名是:language-----节点值是:English
===========结束遍历第2本书的内容===============
SAX解析结束
!!!共有2本书!
null
null
null
null
89
null
------finish-------
null
null
null
null
null
English
------finish-------
SAXTest类:
package com.immoc.test;
import java.io.IOException;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.SAXException;
import com.imooc.entity.Book;
import com.imooc.handler.SAXPAarserHandler;
public class SAXTest {
public static void main(String[] args) {
//获取一个SAXparserFactory的实例
SAXParserFactory factory=SAXParserFactory.newInstance();
//通过factory获取SAXparser实例
try {
SAXParser parser=factory.newSAXParser();
//创建SAXParserHandler对象
SAXPAarserHandler handler=new SAXPAarserHandler();
parser.parse("books.xml", handler);
System.out.println("!!!共有"+handler.getBookList().size()+"本书!");
for (Book book :handler.getBookList() ) {
System.out.println(book.getId());
System.out.println(book.getName());
System.out.println(book.getAuthor());
System.out.println(book.getYear());
System.out.println(book.getPrice());
System.out.println(book.getLanguage());
System.out.println("------finish-------");
}
} 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();
}
}
}
以下是SAXParseHandler类代码:
package com.imooc.handler;
import java.util.ArrayList;
import javax.xml.stream.events.StartElement;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
import com.imooc.entity.Book;
public class SAXPAarserHandler extends DefaultHandler {
int bookIndex=0;
String value=null;
//创建一个book对象
Book book=null;
private ArrayList<Book> bookList=new ArrayList<Book>();
// /**
// *
// * 用来遍历xml文件的开始标签
// */
// @Override
// public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
// // TODO Auto-generated method stub
// super.startElement(uri, localName, qName, attributes);
// }
//
// /**
// *
// * 用来遍历xml文件的结束标签
// */
// @Override
// public void endElement(String uri, String localName, String qName) throws SAXException {
// // TODO Auto-generated method stub
// super.endElement(uri, localName, qName);
// }
public ArrayList<Book> getBookList() {
return bookList;
}
/**
*
* 用来标识解析开始
*/
@Override
public void startDocument() throws SAXException {
// TODO Auto-generated method stub
super.startDocument();
System.out.println("SAX解析开始");
}
/**
*
* 用来标识解析结束
*/
@Override
public void endDocument() throws SAXException {
// TODO Auto-generated method stub
super.endDocument();
System.out.println("SAX解析结束");
}
/**
* 解析xml元素
*
*/
@Override
public void startElement(String uri, String localName,
String qName, Attributes attributes) throws SAXException {
// TODO Auto-generated method stub
//调用DefaultHandler类的startElemnet方法
super.startElement(uri, localName, qName, attributes);
//开始解析book元素的属性
//创建一个book对象
book=new Book();
if(qName.equals("book")){
bookIndex++;
//开始解析book元素的属性
System.out.println("=========开始遍历第"+bookIndex+"本书的内容=========");
// //已知book元素下属性的名称,根据属性名称获取属性值
// String value=attributes.getValue("id");
// System.out.println("book的属性值是:"+value);
//不知道book元素下属性的名称以及个数,如何获取属性名以及属性值
int num=attributes.getLength();
for(int i=0;i<num;i++){
System.out.print("book元素的第"+(i+1)+"个属性名是:"
+attributes.getQName(i));
System.out.println("---属性值是:"
+attributes.getValue(i));
//把bookid写入对象
if(attributes.getQName(i).equals("id")){
book.setId(attributes.getValue(i));
}
}
}else if(!qName.equals("book") && !qName.equals("bookstore")){
System.out.print("节点名是:"+qName+"-----");
}
}
@Override
public void endElement(String uri, String localName, String qName) throws SAXException {
//调用DefaultHandler类的endElemnet方法
super.endElement(uri, localName, qName);
//判断是否针对一本书已经遍历结束
if(qName.equals("book")){
bookList.add(book);
book=null;
System.out.println("===========结束遍历第"+bookIndex+"本书的内容===============");
}
else if(qName.equals("name")){
book.setName(value);
}
else if(qName.equals("author")){
book.setAuthor(value);
}
else if(qName.equals("year")){
book.setYear(value);
}
else if(qName.equals("price")){
book.setPrice(value);
}
else if(qName.equals("language")){
book.setLanguage(value);
}
}
@Override
public void characters(char[] ch, int start, int length) throws SAXException {
// TODO Auto-generated method stub
super.characters(ch, start, length);
value=new String(ch, start, length);
if(!value.trim().equals("")){
System.out.println("节点值是:"+value);
}
}
}
请问到底哪里错了啊,