xml解析

    xiaoxiao2023-11-26  193

    Java中配置文件的三种配置位置及读取方式XML的作用dom4j+xpath解析xml文件

    #三种配置位置及读取方式# 1、同包下的资源文件读取 与读取配置文件的类在同一包 Xxx.class.getResourceAsStream(“config2.properties”); 2、将所有的资源文件放在根目录下 编译后所有的资源文件都会自动进WEB-INF src根目录下 Xxx.class.getResourceAsStream("/config.properties"); 3、直接将资源文件放到web-inf下 WEB-INF(或其子目录下) 再在servlet里面调用 ServletContext application = this.getServletContext(); InputStream is = application.getResourceAsStream("/WEB-INF/config3.properties"); web-inf 下的内容是不能被外部访问到的 #XML的作用# 配置 数据交换 *.properties 文件需要编辑代码 userPage=20 *.xml 静态资源文件:css、js、html、图片、视屏 properties文件的解析方式有java.util.properties这个类来完成 xml文件:由一个工具类来完成 xml的解析四种方法:1、DOM解析;2、SAX解析 由上往下解析;3、JDOM解析;4、DOM4J解析 由外到内解析。其中前两种属于基础方法,是官方提供的平台无关的解析方式;后两种属于扩展方法,它们是在基础的方法上扩展出来的,只适用于java平台。

    一:DOM接口提供了一种通过分层对象模型来访问XML文档信息的方式,这些分层对象模型依据XML的文档结构形成了一棵节点树。无论XML文档中所描述的是什么类型的信息,即便是制表数据、项目列表或一个文档,利用DOM所生成的模型都是节点树的形式。也就是说,DOM强制使用树模型来访问XML文档中的信息。由于XML本质上就是一种分层结构。DOM树所提供的随机访问方式给应用程序的开发带来了很大的灵活性,它可以任意地控制整个XML文档中的内容。然而,由于DOM分析器把整个XML文档转化成DOM树放在了内存中,因此,当文档比较大或者结构比较复杂时,对内存的需求就比较高。  优点:       1、形成了树结构,有助于更好的理解、掌握,且代码容易编写。       2、解析过程中,树结构保存在内存中,方便修改。       3、是一种独立于平台和语言的方法访问文档的内容和结构,使用户页面可以动态变化。增强了页面的交互性。   缺点:       1、由于文件是一次性读取,所以对内存的耗费比较大。       2、如果XML文件比较大,容易影响解析性能且可能会造成内存溢出。       dom节点        二:SAX解析SAX提供的访问模式是一种顺序模式  优点:       1、采用事件驱动模式,对内存耗费比较小。       2、适用于只处理XML文件中的数据时。  缺点:       1、编码比较麻烦。       2、很难同时访问XML文件中的多处不同数据。      三:DOM4J解析 1、合并了许多超出基本XML文档表示的功能。       2、它使用接口和抽象基本类方法。       3、具有性能优异、灵活性好、功能强大和极端易用的特点。       4、是一个开放源码的文件  四、JDOM解析     特征:       1、仅使用具体类,而不使用接口。       2、API大量使用了Collections类。            #dom4j+xpath解析xml文件# xpath等同数据库的select语句 document.selectNodes(xpath);//查一组 document.selectSingleNode(xpath);//查单个 xml可以作为数据传输 每一个接口传输的xml节点及节点内容都不相同,那么对应的解析方式是不是应该写很多个呢? 思考一个xml解析方法解析多种格式的文件 反向思考,    DOM由节点组成 Node 元素节点 属性节点 文本节点 遍历所有元素再找s003比较麻烦,有没有更简单的方法呢 答案是当然有的。

    xpath / 定位路径 在系统中建一个文件叫document/students/student/sid|name @ 属性 students.xml

    最新回复(0)