A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

本帖最后由 谷粒姐姐 于 2018-5-17 10:53 编辑

1.1 上次课内容回顾:
[AppleScript] 纯文本查看 复制代码
JDBC        :
* JDBC的概述:
    * JDBC:Java Database Connectivity
* JDBC的API:
    * Connection:连接.
        * 获得连接.
        * 执行事务的管理.
    * Statement:
        * 执行SQL语句.
            * int executeUpdate(String sql);
            * ResultSet executeQuery(String sql);
            * boolean execute(String sql);
    * ResultSet:
        * getXXX(int idx),getXXX(String name);
* JDBC完成CRUD的操作:
连接池:
* 自定义连接池:(了解)
    * 增强一个类中的某个方法有几种方式:
        * 继承:
            * 控制控制这个类的构造.
       * 装饰者模式:
            * 增强的类和被增强类实现相同的接口.
            * 在增强类中获得被增强的类引用.
                * 接口中方法过多,增强其中一个方法,其他方法都要重写.
        * 动态代理:
            * 被增强的类实现了接口即可.
                * 编写代码的时候麻烦.
* DBCP:
* C3P0:
DbUtils:工具类:
* 使用DBUtils完成CRUD的操作
1.2 案例一:使用XML作为配置文件的方式完成模拟Tomcat.1.2.1 需求:
现在有一套页面,这套页面想被其他人访问到.端口号可以进行修改的-(不修改源码的基础上).
1.2.2 分析:1.2.2.1 技术分析:
【Java基础的网络编程】
【XML的概述】
Ø 什么是XML:
**** 允许用户自定义标签的!!!
[AppleScript] 纯文本查看 复制代码
Ø XML的作用:
* 传输 和 存取数据.
* 软件的配置文件.
Ø XML的使用:
* XML的语法.
【XML的语法】
[mw_shl_code=applescript,true]Ø XML的基本语法:
* XML必须有关闭标签
* 区分大小写
* 属性需要有引号
* 标签必须正确嵌套.
Ø XML的文档声明
* 文档声明:通常出现在XML的第一行第一列的位置!!!
* 写法:
    * <?xml 属性名=”属性值” 属性名=”属性值” ...?>
        * version        :必须的. 使用”1.0”
        * encoding        :字符集. 是使用浏览器打开的时候采用的默认的字符集的编码.
        * standalone        :描述XML文档是否需要依赖其他的文件.
Ø XML的注释
* <!-- XML的注释 -->
Ø XML的元素
* 元素(标签)的命名规范:


[AppleScript] 纯文本查看 复制代码
***** 名称中不能包含冒号(:)
Ø XML的属性
* 属性的名称规范与元素一致.
***** 属性需要使用引号!
Ø XML的特殊字符和CDATA区
* XML的特殊字符:


[AppleScript] 纯文本查看 复制代码
* XML的CDATA区:(CDATA:Character Data)
* <![CDATA[  内容  ]]>
【XML的解析】
Ø XML的解析:从XML文档中获得想要的数据(通过代码完成的.)
Ø XML的解析的方式(*****):
* DOM解析:DOM:Document Object Model.
* SAX解析:Simple Api for XML.
* DOM和SAX的区别:


[AppleScript] 纯文本查看 复制代码
Ø 针对这两种解析的方式,不同的公司提供了不同的API的实现.
* JAXP                :SUN公司提供的一套XML的解析的API.
* JDOM                :开源组织提供了一套XML的解析的API-jdom.
* DOM4J                :开源组织提供了一套XML的解析的API-dom4j.
* pull                :主要应用在Android手机端解析XML.
Ø DOM4J的入门案例步骤:
* 【步骤一】导入jar包.dom4j-1.6.1.jar
* 【步骤二】创建解析器
* 【步骤三】解析文档获得代表文档的Document对象.
* 【步骤四】获得跟节点.
* 【步骤五】从跟节点下查找其他的节点.
* 代码实现:
@Test
        /**
         * 获得元素的内容:查询的操作.
         */
        public void demo1() throws Exception{
                // 创建解析器
                SAXReader reader = new SAXReader();
                // 解析XML的文档
                Document document = reader.read("xml/demo1.xml");
                // 获得跟节点
                Element root = document.getRootElement();
                System.out.println(root.getName());
                // 查找跟节点下的子节点. element() elements();
                Element pElement = root.element("person"); // 查找的是第一个person元素
                // root.elements("person").get(1); // 查找的是第二个person元素
                Element nElement = pElement.element("name");
                Element aElement = pElement.element("age");
                Element sElement = pElement.element("sex");
                System.out.println(nElement.getText());
                System.out.println(aElement.getText());
                System.out.println(sElement.getText());
        }
Ø XPath:
* dom4j支持XPath的jar包.
    * jaxen-1.1-beta-6.jar
* dom4j的XPath支持的API:
    * List document.selectNodes(String xPath);
    * Node document.selectSingleNode(String xPath);
* 代码:
        @Test
        /**
         * DOM4J的XPath的写法:
         */
        public void demo2() throws Exception{
                // 创建解析器:
                SAXReader reader = new SAXReader();
                // 解析XML返回Document对象.
                Document document = reader.read("xml/demo1.xml");
                /*List<Node> list = document.selectNodes("//name");
                for (Node node : list) {
                        Element element = (Element) node;
                        System.out.println(element.getText());
                }*/
               
                List<Node> list = document.selectNodes("//person['@id']");
                for (Node node : list) {
                        Element element = (Element) node;
                        System.out.println(element.attributeValue("id"));
                }
        }
[/mw_shl_code]
1.2.3 代码实现:
【步骤一】:将基础班的Socket编写的代码复制到工程中.
【步骤二】:新建xml.在conf/server.xml
【步骤三】:使用DOM4J解析XML
public class MyServer {
        
        public static void main(String[] args) throws Exception {
                // 解析XML:
                // 创建解析器
                SAXReader reader = new SAXReader();
                // 解析XML文档:
                Document document = reader.read("conf/server.xml");
                Element element = (Element)document.selectSingleNode("//Connector['@port']");
                String port = element.attributeValue("port");
                // ServerSocket 对象可以监听端口
                ServerSocket serversocket = new ServerSocket(Integer.parseInt(port));
                while(true) {
                        Socket socket = serversocket.accept();        // 等待客户端的连接请求,一旦有请求过来,就结束阻塞,返回客户端对象
                        //System.out.println(socket.getInetAddress());
                        // 一旦有客户来访问, 就另开一个新线程去提供服务, main线程继续等待下一个客户的连接
                        new Thread(new MyService(socket)).start();
                }
        }
}
1.2.4 总结:1.2.4.1 XML的约束:
Ø XML的约束的额概述:
* 什么是XML的约束        :就是用来约束XML的文档中可以出现哪些标签,不能出现哪些标签,标签中是否有顺序,出现的次数.
* XML的约束                        :用来规范XML的写法.
***** XML的约束的种类及区别?
     * DTD 和 Schema        :
         * 区别:
             1.DTD语法是自成一体的.Schema语法就是XML的语法.
             2.Schema的语法就是XML的语法所以更容易被解析器所解析.
             3.Schema支持名称空间.
             4.Schema有比DTD更加强大的语义和语法的约束.
[AppleScript] 纯文本查看 复制代码
Ø DTD的语法        :(了解)
* DTD的引入方式:
     * 内部的DTD:
    <!DOCTYPE persons [
       
    ]>
     * 外部的DTD:
         * 一种本地DTD:
         <!DOCTYPE persons SYSTEM "unknown.dtd">
         * 一种网络DTD:
         <!DOCTYPE persons PUBLIC "//UNKNOWN/" "unknown.dtd">
* DTD的语法:
     * 元素:
         * <!ELEMENT 元素名 元素类型>
             * 元素类型:
                 * EMPTY
                 * ANY
                 * 子元素
                     * 是否有序: 使用 逗号(,)或者竖线(|)表示.
                     * 出现的次数:?:零次或一次 +:一次或多次 *:零次或多次
                 * PCDATA
    * 属性:
        * <!ATTLIST 元素名称 属性名称 属性的类型 属性的约束>
            * 属性的类型:
                * ID类型:表示属性值需要是唯一的.
                * CDATA类型:普通的字符串.
                * 枚举:
            * 属性的约束:
               
Ø Schema的语法:(了解)
<?xml version="1.0" encoding="UTF-8"?>
<!--
    名称空间:一个XML只能引入一个DTD约束文档.使用了Schema约束XML文档,一个XML可以引入多个Schame的约束!!!
                      如果再多个Schema文档中定义了相同的属性名称 该怎么办?
      * 名称空间类似于java中的package.通过名称空间区分 标签或属性来自于哪个文档的!!!通常名称空间唯一的不重复的即可.一般情况下使用一个URL地址表示一个名称空间.
      
[AppleScript] 纯文本查看 复制代码
        xmlns                                :xml name sapace .代表当前的文档应用的名称空间.
        targetNameSpace                :目标名称空间.
        elementFormDefault        :
-->
<schema
xmlns="http://www.w3.org/2001/XMLSchema"
targetNamespace="http://www.itheima.com/ee25"
elementFormDefault="qualified">
        <!-- 复杂标签 -->
        <element name="persons">
                <!-- 复杂类型 -->
                <complexType>
                        <sequence maxOccurs="unbounded" minOccurs="1">
                                <element name="person">
                                        <complexType>
                                                <sequence>
                                                        <!-- 简单标签 -->
                                                        <element name="name" type="string"></element>
                                                        <element name="age" type="int"></element>
                                                        <element name="sex" type="string"></element>
                                                </sequence>
                                                <attribute name="id" type="string" use="required"/>
                                        </complexType>
                                </element>
                        </sequence>
                </complexType>
        </element>
</schema>

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马