下面是handler解析数据的方法
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
public class MyHandler extends DefaultHandler {
private HashMap<String, String> map = null;// 存储单个解析的完整对象
private List<HashMap<String, String>> list = null;// 存储全部的解析对象
private String currentTag = null; // 正在解析的元素的标签
private String currentValue = null;// 正在解析的元素的值
private String nodeName = null;// 解析节点的名称
public MyHandler(String nodeName) {
this.nodeName = nodeName;
}
public List<HashMap<String, String>> getList() {
return list;
}
public void startDocument() throws SAXException {
// 当读到第一个开始标签的时候,开始触发
list = new ArrayList<HashMap<String, String>>();
}
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
// 当遇到文档的开头的时候,调用这个方法
if (qName.equals(nodeName)) {
map = new HashMap<String, String>();
}
if (attributes != null && map != null) {
for (int i = 0; i < attributes.getLength(); i++)
map.put(attributes.getQName(i), attributes.getValue(i));
}
currentTag = qName;
}
public void characters(char[] ch, int start, int length)
throws SAXException {
// 处理从xml文件所读取到的内容
if (currentTag != null && map != null) {
currentValue = new String(ch, start, length);
if (currentValue != null && !currentValue.trim().equals("")
&& !currentValue.trim().equals("\n")) {
map.put(currentTag, currentValue);
}
}
currentTag = null;
currentValue = null;
}
public void endElement(String uri, String localName, String qName)
throws SAXException {
// 遇到结束标记的时候,调用此方法
if (qName.equals(nodeName)) {
list.add(map);
map = null;
}
}
}
下面是读取输入流中xml数据,并将这些数据一List方式返回
import java.io.InputStream;
import java.util.HashMap;
import java.util.List;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import com.sax.handler.MyHandler;
public class SaxService {
public static List<HashMap<String, String>> readXML(InputStream input, String nodeName){
try {
//创建一个解析xml的工厂对象
SAXParserFactory apf = SAXParserFactory.newInstance();
SAXParser parser = apf.newSAXParser();//解析xml内容
MyHandler handler = new MyHandler(nodeName);
parser.parse(input, handler);//用给定的handler解析input输入流中的内容
input.close();
return handler.getList();
} catch (Exception e) {
System.out.println(e);
}
return null;
}
}
下面是从服务器中得到xml文件,并将其转化为数据流
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
public class HttpUtils {
public static InputStream getXML(String path) {
InputStream input = null;
try {
URL url = new URL(path);
if (url != null) {
HttpURLConnection connection = (HttpURLConnection) url
.openConnection();
connection.setReadTimeout(3000);
connection.setDoInput(true);
connection.setRequestMethod("GET");
int code = connection.getResponseCode();
if (code == 200) {
input = connection.getInputStream();
}
}
} catch (Exception e) {
// TODO: handle exception
}
return input;
}
}
下面就是测试代码了
import java.io.InputStream;
import java.util.HashMap;
import java.util.List;
import com.sax.http.HttpUtils;
import com.sax.service.SaxService;
public class Test {
public static void main(String[] args) {
String path = "http://127.0.0.1:8080/myhttp/person.xml";
try {
InputStream input = HttpUtils.getXML(path);
List<HashMap<String, String>> list = SaxService.readXML(input,
"person");
for(HashMap<String, String> map :list){
System.out.println("-test->"+map.toString());
}
} catch (Exception e) {
System.out.println(e);
}
}
}
分享到:
相关推荐
这种方式使得SAX解析器在处理大型XML文件时,相比DOM(Document Object Model)解析器具有更低的内存消耗和更快的解析速度。 三、SAX解析流程 1. 创建XML解析器:首先,我们需要创建一个XMLReader对象,它是SAX...
SAX解析器采用事件驱动的方式,逐行读取XML文件,当遇到元素开始、结束、属性、文本等事件时,会触发相应的回调函数。这种方式内存占用低,适合处理大文件,但操作XML数据不如DOM直观,需要编写事件处理器来处理这些...
然后,我们创建一个主类,用于初始化SAX解析器并开始解析XML文档。 ```java import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; import java.io.File; public class SaxDemo { ...
本压缩包文件“XML-java.rar”包含了关于使用Java解析XML的实例,特别强调了SAX解析器的使用,并且提到了使用JDOM和JOM4J这两个Java库来处理XML。 1. **DOM解析**:DOM是一种树型结构,它将整个XML文档加载到内存中...
而SAX解析器采用事件驱动的方式,逐行读取XML文件,适合处理大型XML文件以避免内存消耗。 对于多级XML,DOM解析更便于操作。以下是一个使用Java DOM解析XML的步骤: 1. 引入必要的库: 需要引入`javax.xml....
综上所述,这个Java实例是关于如何利用SAX解析器高效地读取和处理RSS数据,适用于那些需要处理大量XML数据且对内存效率有较高要求的项目。理解并掌握SAX解析器的工作原理和使用方法,对于任何Java开发者来说都是一个...
程序员通过实现SAX解析器的回调接口来处理这些事件,从而解析XML内容。这种方式使得SAX解析器具有高效、低内存占用的特性。 **SAX解析XML的优点:** 1. **效率高**:SAX解析器只读取和处理当前需要的部分,不需要将...
- 创建SAX解析器:使用`org.xml.sax.helpers.DefaultHandler`定义事件处理器,并通过`org.xml.sax.XMLReader`设置处理器。 - 解析XML文件:使用`XMLReader`的`parse()`方法解析XML文件。 - 处理事件:在事件处理器的...
- 在Java中,我们通常使用`org.xml.sax.XMLReader`接口来代表SAX解析器。不过,这个接口没有提供直接的实例化方法,我们需要通过`org.xml.sax.helpers.XMLReaderFactory`来获取一个实现该接口的实例。 3. **SAX...
SAX解析器是一种基于事件驱动的解析方式,它不会一次性加载整个XML文档,而是逐行读取并触发相应的事件,如开始元素、结束元素、字符数据等。这种方式节省了内存,适合处理大型XML文件,但不支持随机访问,且需要...
首先,SAX解析器以流式方式读取XML文档,当遇到文档的不同部分时,会触发相应的事件,如开始文档、开始元素、结束元素等。开发者可以注册事件处理器来响应这些事件,从而获取XML元素的信息。 1. **初始化解析器**:...
总结来说,"saxloadxml"项目提供了使用SAX解析XML文件的一个实例,可以帮助开发者了解如何利用SAX解析器处理XML文档,尤其是在性能和内存使用方面有较高要求的情况下。通过学习和实践这个项目,你可以提升处理XML...
SAX解析器的工作原理是基于事件驱动的,它在解析XML文档时会触发一系列的事件,如开始文档、结束文档、开始元素、结束元素等。开发者通过实现SAX解析器的回调接口(如ContentHandler),在这些事件发生时执行相应的...
Java SAX(Simple API for XML)解析XML是一种基于事件驱动的解析方法,主要用于处理大型XML文档。与DOM(Document Object Model)解析器不同,SAX不将整个XML文档加载到内存中,而是逐个读取XML文档的元素和属性,...
1. SAX解析器: SAX是一种基于事件驱动的解析器,它不会一次性加载整个XML文档到内存,而是逐行读取,当遇到某个元素、属性或其他结构时,会触发相应的事件处理器方法。这种方式适用于处理大型XML文档,因为它占用的...
SAX解析器是一种基于事件驱动的解析器,它不会一次性加载整个XML文档到内存中,而是逐行读取,当遇到XML文档中的元素、属性等特定事件时,会触发相应的回调方法。这种方式非常适合处理大型XML文件,因为它可以有效地...
Java 中使用 SAX 方式解析 XML 文件需要实现一个事件处理器,来处理解析器触发的事件。 SAX 的优点 * SAX 方式可以处理大型 XML 文档,占用较少内存 * SAX 方式解析速度较快 SAX 的缺点 * SAX 方式不能随机访问 ...
可以考虑使用SAX或者StAX解析器,它们是事件驱动的,只在需要时处理XML数据,减少内存占用。 5. **安全性**: - 防止SQL注入:使用预编译的`PreparedStatement`可以避免SQL注入攻击,确保参数安全。 - 输入验证:...
1. **解析XML**:Java提供了多种解析XML的方法,包括DOM(文档对象模型)、SAX(简单API for XML)和StAX(流式API for XML)。DOM将整个XML文档加载到内存中形成一个树形结构,适合小型文件;SAX是一种事件驱动的...