关于XML小故事——解析

2022-11-22 14:26:04 浏览数 (1)

1.XML作用:(XML 应用于 web 开发的许多方面,常用于简化数据的存储和共享。)    1.1配置   需要:  *.xml和*.properties、*.ini、*.yaml

配置之间的关系

标签

用途

解释

<dubbo:service/>

服务配置

用于暴露一个服务,定义服务的元信息,一个服务可以用多个协议暴露,一个服务也可以注册到多个注册中心

<dubbo:reference/> 2

引用配置

用于创建一个远程服务代理,一个引用可以指向多个注册中心

<dubbo:protocol/>

协议配置

用于配置提供服务的协议信息,协议由提供方指定,消费方被动接受

<dubbo:application/>

应用配置

用于配置当前应用信息,不管该应用是提供者还是消费者

<dubbo:module/>

模块配置

用于配置当前模块信息,可选

<dubbo:registry/>

注册中心配置

用于配置连接注册中心相关信息

<dubbo:monitor/>

监控中心配置

用于配置连接监控中心相关信息,可选

<dubbo:provider/>

提供方配置

当 ProtocolConfig 和 ServiceConfig 某属性没有配置时,采用此缺省值,可选

<dubbo:consumer/>

消费方配置

当 ReferenceConfig 某属性没有配置时,采用此缺省值,可选

<dubbo:method/>

方法配置

用于 ServiceConfig 和 ReferenceConfig 指定方法级的配置信息

<dubbo:argument/>

参数配置

用于指定方法参数配置

 1.2数据交互(获取第三方数据)

么叫做交互?简单来说就是A导致B,也就是A---->B,即A和B之间有某种逻辑关系,这个逻辑关系是通过算法、程序连接和控制的,如 果A发⽣了那么B就会发⽣。交互,表⾯是⾏为的交互,本质上是数据的交互。交互,表⾯是⾏为的交互,本质上是数据的交互。如果⽤计算机术语来表述,交互也就是所谓的可编程性。 这么说可能还是有些抽象,如果再具体⼀点 所谓交互,就是我们平时所说的注册、登录、转账、交易、分红、创建、销毁等这⼀系列的操作。

XML:webservices(axis2) -> xml -> 手机归属地、天气  JSON  ajax 无刷新

2.Java中3种配置位置及读取方式

第一种:XML

第二种:*.properties(属性文件)

第三种:ini(不常用)    2.1如何使用Properties读取配置文件       1)*.properties文件以键值对的方式存储数据;       2)使用Properties类读取配置文件; 

   2.2 配置位置       1)存放于根目录下,/代表获取src根目录的绝对路径       2)存放于同一类的包下,不加/代表同类名包下的相对路径;       3)存放于WEB-INF目录下

代码实例如下:(2.1与2.2的代码案例供参考)(Demo2)

代码语言:javascript复制
package com.zking.xmlanlysis.util;

import java.io.InputStream;

public class Demo2 {

	public static void main(String[] args) {
		//1)存放与根目录下,/代表获取src根目录的绝对路径
		InputStream is= Demo2.class.getResourceAsStream("/student.xml");
		System.out.println(is);
		//2)存放于同一类的包下,不加/代表同类名包下的相对路径
	    InputStream is1=Demo2.class.getResourceAsStream("demo.properties");
		System.out.println(is1);
		//3)存放与WEB-INF目录下
		//servlet生命周期:初始化(init)、服务处理(service)、销毁(destory)
		//public clss LoginServlet extends HttpServlet
		//dogGet
		//doPost
		//init()
		//this.getReourceAsStream("/WEB-INF/db.properties")
		//WebContent(根目录)
		//WEB-INF
		//META-INF
		

	}

}

3.dom4j xpath解析xml文件

(实际上,dom4j指的是一个专门用来解析XML文件的程序! 而xpath就等同于数据库中的select语句!)     1)xpath类似数据库中的select语句;     2)Document有节点(Node)组成:元素节点、属性、文本等;     3)selectNodes()获取节点下所有子节点;     4)selectSingleNodes()获取单个节点信息;     5) xpath语法:/(定位路径)、@(获取属性)     案例:解析student.xml,先展示Demo3的代码:

代码语言:javascript复制
package com.zking.xmlanlysis.util;

import java.io.InputStream;
import java.util.List;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;

public class Demo3 {

	public static void main(String[] args) {
		try {
			//1.获取student.xml文件输入流
			InputStream is= Demo3.class.getResourceAsStream("/student.xml");
			//2.创建SAXReader对象
			SAXReader saxReader=new SAXReader();
			//3.获取文件输入流并转换成Document对象
			//document:包含元素节点、属性以及文本
			Document doc= saxReader.read(is);
			//4.循环遍历
			//1)selectNodes:获取多个节点,返回List
			//2)selectSingleNode:获取单个节点
			//3)xpath语法:/代表定位路径@获取属性
			List<Node> root= doc.selectNodes("students/student");
			for (Node node : root) {
				//5.将Node节点转换成元素节点Element(student)
				Element elem=(Element) node;
				//6.获取元素节点的属性
				String pid=elem.attributeValue("pid");
				System.out.println("pid=" pid);
				//7.获取student节点下的name
				Node nameNode= elem.selectSingleNode("name");
				System.out.println(nameNode.getText());
			}
			//简化:xpath语法
			//[@id="title-content"/span[1]
			Node node = doc.selectSingleNode("/students/student[@pid='p02']/name");
			System.out.println(node.getStringValue());
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

	}

}

那么简单的student.xml的代码如下:

代码语言:javascript复制
<?xml version="1.0" encoding="UTF-8"?>
<students>
	<student pid="p01">
		<name>张三</name>
	</student>
	<student pid="p02">
		<name>李四</name>
	</student>	
	<student pid="p03">
		<name>王五</name>
	</student>		
</students>

今天就分享到这里啦!感谢支持!

祝:高三学子旗开得胜,成功上岸!

0 人点赞