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>
今天就分享到这里啦!感谢支持!