SAX是一种基于事件驱动的XML解析方式,通过startDocument()、startElement()、characters()、endElement()和endDocument()等回调函数逐行解析XML,无需加载整个文档,内存占用小、解析速度快,适用于处理大型文件和资源受限环境,但仅支持单向读取,不可修改文档,适合流式处理场景。

SAX(Simple API for XML)是一种基于事件驱动的XML解析方式,与DOM不同,它不需要将整个XML文档加载到内存中,因此在处理大型XML文件时具有明显优势。
1. 基于事件驱动
SAX采用事件机制来解析XML文档。当解析器读取到文档的不同部分(如开始标签、结束标签、文本内容等)时,会触发相应的事件回调函数。
常见的事件包括:- startDocument():文档开始时调用
- startElement():遇到开始标签时调用
- characters():处理标签间的文本内容
- endElement():遇到结束标签时调用
- endDocument():文档解析完成时调用
开发者需要继承DefaultHandler类并重写这些方法来实现自定义逻辑。
2. 内存占用小
SAX是逐行读取XML内容,不保存整个文档结构,因此内存消耗非常低。
本支付接口的特点,主要是用xml文件来记录订单详情和支付详情。代码比较简单,只要将里面的商户号、商户key换成你自己的,将回调url换成你的网站,就可以使用了。通过这个实例也可以很好的了解一般在线支付接口的基本工作原理。其中的pay.config文件记录的是支付详情,order.config是订单详情
- 处理大体积XML文件(如几百MB甚至GB级)
- 服务器资源有限,需控制内存使用
- 只需提取部分数据,无需保留完整树结构
3. 解析速度快
由于SAX是顺序读取、边读边处理,省去了构建DOM树的过程,解析效率更高。
但注意:- 只能从前往后读取,不支持随机访问
- 无法像DOM那样修改节点或回溯结构
- 一旦跳过某部分内容,就不能再次获取
4. 只读模式,不可修改文档
SAX仅用于读取和解析XML,不能对原始文档进行增删改操作。
如果需要修改XML内容,应结合其他方式(如先解析再生成新文件)。基本上就这些。SAX适合高效、轻量地读取XML数据,尤其适用于大数据量、单向处理的场景。虽然编程逻辑比DOM复杂一些,但资源开销小,是流式处理XML的优选方案。









