Java基础XML相关

模拟Servlet:

       为了灵活实现的不同路径(/hello)执行不同的资源( HeIIoMyServlet)我们需要使用XML进行配置;为了限定XML内容,我们需要使用xml约束(DTD或schema);为了获得xml的内容,我们需要使用dom4j进行解析。然后可以通过反射进行创建对象,获取其中的方法。

XML语法:

文档声明:

<?xml version="1.0" encoding="UTF-8"?>

①、文档声明必须为<?xml开头,以?>结束;

②、文档声明必须从文档的0行0列位置开始:(注释也不能加!!!)

③、文档声明只有属性:

a)     versioin:指定XML文档版本。必须属性,因为我们不会选择1.1,只会选择1.0;

b)     encoding:指定当前文档的编码。可选属性,默认值是。utf-8:

元素element:

①.元素是XML文档中最重要的组成部分,

②.普通元素的结构开始标签、元素体、结束标签组成。例如:<hello>大家好</hello>

③.元素体:元素体可以是元素,也可以是文本,例如:<b><a>你好</a ></b>

④.空元素:空元素只有开始标签,而没有结束标签,但元素必须自己闭介,例如:<c/>

⑤.元素命名:

a)     区分大小写

b)     不能使用空格,不能使用冒号:

c)     不建议以XML,  xml,  Xml开头

⑥.格式化良好的XML文档,必须只有一个根元素。

3、属性:

①.属性是元素的一部分,它必须出现在元素的开始标签中

②.属性的定义格式:属性名=属性值,其中属性值必须使用单引或双引

③.一个元素可以有O ~ N个属性,但一个元素中不能出现同名属性

④.属性名不能使用空格、冒号等特殊字符,且必须以字母开头

4、注释:

XML的注释与HTML相同,即以“<!--”开始,以“-->”结束。注释内容会被XML解析器忽略!

DTD:

DTD (Document Type Definition ),文档类型定义,用来约束XML文档。规定XML文档中元素的名称,子元素的名称及顺序,元素的属性等。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE web-app SYSTEM "web-app_2_3.dtd">
<web-app>
    <servlet>
        <servlet-name>HelloServlet</servlet-name>
        <servlet-class>com.oracle.demo01.HelloServlet</servlet-class>

    </servlet>
    <servlet-mapping>
        <servlet-name>HelloServlet</servlet-name>
        <url-pattern>/hello</url-pattern>
    </servlet-mapping>

</web-app>

元素声明:

定义元素语法:<!ELEMENT元素名 元素描述>

    元素名:自定义

    元素描述包括 : 符号和数据类型

          常见符号: ?  *  +  ()  |  ,

          常见类型:#PCDATA表示内容是文本,不能是子标签

Schema约束:

介绍:

①、Schema是新的XML文档约束:

②、 Schema要比DTD强大很多,是DTD替代者;

③、Schema本身也是XML文档,但Schema文档的扩展名为xsd,而不是xml .

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://www.example.org/web-app_2_5" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://www.example.org/web-app_2_5 web-app_2_5.xsd"
    version="2.5">
    <servlet>
        <servlet-name></servlet-name>
        <servlet-class></servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name></servlet-name>
        <url-pattern></url-pattern>
    </servlet-mapping>
</web-app>

dom4j解析:

XML的解析方式:

DOM:要求解析器把整个XML文档装载到内存,并解析成一个Document对象。

        a)  优点:元素与元素之间保留结构关系,故可以进行增删改查操作。

        b)  缺点:XML文档过大,可能出现内存溢出显现。

API使用:

package com.oracle.demo04;

public class MyServlet {
    public void init(){
        System.out.println("init()正在执行");
    }
    public void service(){
        System.out.println("service()正在执行");
    }
    public void destroy(){
        System.out.println("destory()正在执行");
    }
}
package com.oracle.demo04;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
//将数据按Schema约束写到XML里,然后通过dom4j解析出所有的元素,再用反射创建对象再调出其所有的方法!!!
public class Demo {
    public static void main(String[] args) throws DocumentException, ClassNotFoundException, InstantiationException, IllegalAccessException {
        // 1.获取解析器
        SAXReader sax=new SAXReader();
        // 2.获得document文档对象
        Document doc=sax.read("src/com/oracle/demo04/web.xml");
        // 3.获取根元素
        Element element=doc.getRootElement();
        // 4.判断元素名称为servlet的元素
        Element servlet=element.element("servlet");
        // 5.获取servlet-class元素
        Element className=servlet.element("servlet-class");
        //System.out.println(className.getText());获取当前元素的文本内容
        //开始反射获取MyServlet的字节码文件对象
        Class c=Class.forName(className.getText());
        //快速创建对象
        Object obj=c.newInstance();
        //向下转型
        MyServlet my=(MyServlet) obj;
        my.init();
        my.service();
        my.destroy();
    }
}

猜你喜欢

转载自www.cnblogs.com/heitaitou/p/12904774.html