您的位置:首页 > 编程语言 > Java开发

JavaEE实战——XML语法和约束技术

2016-06-20 15:11 477 查看

MyEclipse8.5

1、配置workspace ----- 建议不要采用含有空格和中文目录,所有代码保存workspace空间中

2、新建工程时,设置工程需要jre环境

MyEclipse提供多种内置layout --- 每种布局 界面不同,菜单不同

工程的属性
编码集 --- 导入其它工程时,注意编码类型一致

java build path 设置 classpath位置 ,指定当前工程引入类库

source中指定.java 文件 和.class文件 存放位置

librialies 指定当前工程引用类库

Java Compiler 指定 .java 采用 那个 版本 编译 .class文件 ----- 编译器版本

当jre版本低于编译器版本 : Bad version number in .class file

3、对已经存在工程进行分组 working set,通过分组隐藏不需要使用工程

4、快捷键

alt+/  Content Assist模板键  --- 将代码快速补全  ---- windows 首选项 java editor templates 

ctrl+1 Quick Fix快速修复  提供代码修改建议

* 使用alt+/ 无反应 修改快捷键设置  window首选项 general --- keys 

* 设置代码 保存时进行格式化 windows首选项 java -editor - save actions

程序调试

java程序员核心能力 --- 代码Debug能力

1、当代码出错了 ---  查看错误信息 --- 找到错误发生位置

* 从上向下找第一行你写的程序

2、根据经验猜测错误原因 

通过sysout或者日志技术 打印关键数据信息到控制台

通过Eclipse自带断点调试功能,查看关键位置数据 ----- 断点调试 Break Point  ----- 程序通过Debug as 运行

* F5和F7 一起使用,查看具体代码实现  F6 单独使用直接跳到代码下一行  右键变量--watch  断点调试完--记得清除断点

F3 查看类代码

F4 查看类继承关系

关于代码测试工作 ----- 测试:白盒测试和黑盒测试

白盒测试测试代码结构和逻辑(可见代码测试),黑盒测试测试代码功能和性能(不可见代码测试)

* 白盒测试局限性 1、白盒测试不可能测试所有代码 2、白盒测试难度比较高  ---- 白盒测试交给软件开发工程师自己测

单体测试是一种白盒测试,测试代码功能模块 -- 测试代码单个功能

junit 是java 的单体测试技术

1、编写junit 在工程引用junit 类库

2、编写单体测试用例

* 创建public void 无参数的方法 、在方法前添加@Test 注解

3、每个测试方法 相当于以前编写main 函数,每个测试方法可以单独执行

在使用junit进行测试当方法非常多,每个方法输出内容到控制台,人们无法通过人工进行检查

* 自动化结果检查 --- 断言 Assert 

断言原理:调用方法,调用方法前,准备测试数据、测试数据运行结果 ------ 比较实际结果与预期结果是否相同

* 编写单体测试时,不要仅测试正确的数据和结果,测试不正确数据(非法数据)

XML简介

XML技术:与数据相关技术,在企业中xml技术常用来存储数据和传输数据 ,流行原因 -----
xml与任何编程语言无关


xml 可用于 php、java、.net 任何编程语言

* 通过标签来 标记数据

什么是标记语言?

<xxx>aaa</xxx> 典型标记语言 HTML ---- 用标记 修饰文本信息

XML标记随意定义 --- 可扩展

XML典型存储和传输应用:

1、XML 充当数据库 保存数据信息 --- 试题采用xml保存的 、google 数据信息通过xml格式保存

2、在AJAX传输数据 、WebService技术 网络中传输数据时,格式采用xml

在HTML中预定义了很多标记,每个标记都有相应显示效果,xml所有标记没有被预定义

在xml中 <name>HLG</name> ----  想确定name标记含义 ,需要对xml 添加约束

XML语法

1、文档声明
2、元素

3、属性

4、注释

5、CDATA块

6、处理指令

任何xml必须具备文档声明 <?xml version="1.0" ?>

XML是一种标记语言 存储和传输数据 --- 保存数据内容

没有指定xml 编码集 --- 默认采用ISO-8859-1 编码 (不支持中文数据)

* 注意问题 当xml 指定encoding="utf-8" 是浏览器查看编码集  ------ 浏览器查看编码集必须要和文件保存编码集一致

* 新建记事本程序采用系统默认编码集 --- 默认编码集gbk ---- 使用utf-8编码 另存为

当声明standalone = "yes" 该xml是独立xml 不依赖外面其它文件,standalone = "no" 该xml 依赖外部一些文件

XML 通过元素描述复杂关系模型数据:



XML树形结构:



XML语法规范

1、所有xml元素必须结束 

<abc></abc> ----- 在xml 文件中如果标签中没有内容 自结束 <abc />

2、标签不允许交叉嵌套

3、有且仅有一个根元素

4、xml文件中 空格和换行 会被解析器进行解析的

5、严格区分大小写,元素和属性名称不能以数字开始

属性定义语法 <元素名称 属性名称="属性值" 属性名称="属性值" ....>

一个元素定义多个属性的,每个属性值必须使用单引号和双引号

6、属性的值必须用单引号或者双引号 引起来

7、xml注释与html注释相同 <!-- --> 注释不能嵌套

CDATA区域内 保留不被解析器解析的内容 ----通常存放特殊代码,这些代码造成xml格式混乱  语法: <![CDATA[内容]]>

CDATA和转义字符在哪些情况使用?区别?

* 优先使用CDATA XML技术存储数据,传输数据、解析数据

8、通过PI指令控制xml显示样式 (指令之前不能有注释)--- 处理指令用来指挥解析XML文档内容

当xml 使用pi指令 引用CSS(XML文档中使用xml-stylesheet指令通知XML解析引擎,应用css文件显示xml文档内容)--- 效果等同于HTML,进行页面数据展示

<?xml-stylesheet type="text/css" href="1.css"?> --- 处理指令必须以"<?"开头,"?>"结尾,XML声明语句就是最常见的一种处理指令 --- <?xml version="1.0" encoding="UTF-8"?>

* 通过xml进行显示数据 ,通过XSLT 修饰xml数据显示 (类似CSS) 例如<xsl:for-each>元素 详情见W3C开发文档

XML 技术应用 两大类

1、传输和存储数据 ----- 程序员为了简化开发,不对xml使用约束技术

* 不使用xml约束技术,xml 格式不一定正确

* 所有xml 数据内容生成,解析过程 都是通过程序来完成的
2、使用xml 作为配置文件

Android SSH ----- 程序员为了保证xml元素准确性,通常xml文档使用约束技术的

什么是xml约束?在XML技术里,可以编写一个文档来约束一个XML文档的书写规范,这称之为XML约束。

3、为什么xml使用约束? 使用了约束的xml文档 --- 元素内容格式更加规范 

如果企业中有的xml没有使用约束 ------ 通过程序生成xml和解析xml时,不使用约束,代码更加简单

4、XML约束技术 DTD 和 Schema 

DTD技术快速入门

1、编写数据xml --- books.xml

2、编写dtd文件

* 为文档每一个元素(不同名称) <!ELEMENT 

语法 <!ELEMENT 元素名称 子元素>

如果元素内部是文本 --- #PCDATA

3、将xml文件与dtd文件关联起来

DTD与xml关联三种方式:

1、内部DTD ----- 语法 <!DOCTYPE 根元素 []> 

2、外部DTD (引用本地DTD) ----- 语法 <!DOCTYPE 根元素 SYSTEM "本地DTD文件位置" >

3、公共DTD (引用网络上DTD)  <!DOCTYPE 文档根结点 PUBLIC "DTD名称" "DTD文件的URL">

* 公共DTD 使用 名称 W3C规范官方组织规定的



元素(ELEMENT)定义:

* 内容特定符号含义

() 子元素、分组

, 代表子元素顺序

+ * ?  ---- 正则表达式 + 1到多个 、* 任意个(0到多个)、 ? 0或者1个

| 多选一 ---- <!ELEMENT book (name,(price|number))>

特殊元素内容:文本类型内容 #PCDATA  子元素内容如果为空 EMPTY 

属性(ATTLIST)定义:

语法:<!ATTLIST 元素名称 属性列表 >

属性列表: 

属性名称 类型 约束

属性名称 类型 约束

属性名称 类型 约束

属性名称 类型 约束

属性类型:

1、CDATA 文本类型属性

2、(值1|值2|值3 ) 三个值选一个

3、ID 表示属性值唯一 类似于数据库中的索引要是唯一的 --- 并且ID属性值不能以数字开始

约束:

1、#REQUIERD 属性必须

2、#IMPLIED 属性可选

3、fixed value 属性值固定

4、default 默认值

举例:

<!ATTLIST book 
bid ID #REQUIRED
author (金庸|古龙) "金庸"

>

<book bid="b100" author="古龙"></book>

<book bid="b200"></book>

实体(ENTITY)定义:

对于xml数据内容重复,可以抽取实体

实体用于为一段内容创建一个别名,以后在XML文档中就可以使用别名引用这段内容了

语法:<!ENTITY 实体名称 "实体内容" >

引用方式:&实体名称;

举例:

<!ENTITY itcast "传智播客">

<book>
<publish>&itcast;</publish>

</book>

<book>
<publish>&itcast;</publish>

</book>

代码示例:

books.dtd:

<?xml version="1.0" encoding="UTF-8"?>
<!ELEMENT books (book)>
<!ELEMENT book (name,price)>
<!ELEMENT name (#PCDATA)>
<!ELEMENT price (#PCDATA)>


books.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE books SYSTEM "books.dtd">
<books>
<book>
<name>java高效编程</name>
<price>100</price>
</book>
</books>


book2.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!-- 使用内部DTD约束XML [] 内部编写DTD内容-->
<!DOCTYPE books [
<!ELEMENT books (book+)>
<!ELEMENT book (name,(number|price),publish)>
<!ELEMENT name (#PCDATA)>
<!ELEMENT price EMPTY>
<!--ID属性 不能以数字开始 -->
<!ATTLIST book
bid ID #REQUIRED
author (金庸|古龙) "金庸"
>
<!ELEMENT publish (#PCDATA) >
<!-- 将公共的重复内容 提取实体-->
<!ENTITY itcast "传智播客 JavaEE" >
]>
<books>
<book bid="b100" author="古龙">
<name>java</name>
<price />
<publish>&itcast;</publish>
</book>
<book bid="b200">
<name>java</name>
<price />
<publish>&itcast;</publish>
</book>
</books>

XML Schema 

使用一套预先定义好元素和属性 开发的 

----- 预先定义好元素和属性 规定了schema 结构和内容

----- 定义schema 规定xml文档 格式和内容

步骤:预先已经定义好元素和属性 ------> 定义schema  -------> 定义xml实例

Schema本身也是xml ,不像DTD使用单独语法

将schema中定义元素,绑定URI地址(名称空间)上,用来唯一标识元素来自哪个schema 。

* 为什么要有名称空间? 一个xml实例 引用多个Schema ,当两个schema定义同名元素,为了区分同名元素引用自哪个文档。

Schema原理



Schema快速入门

1、编写数据xml文件

2、编写schema文件 .xsd 

    1) 引入 W3C 名称空间 xmlns="http://www.w3.org/2001/XMLSchema"

        每一个元素 对应一个 <element name="" type=""> --- 对于简单元素,可以编写type属性

        区分复杂元素和简单元素 --- 包含子元素或者属性的元素叫做复杂元素 --- <complexType></complexType>
强调子元素出现顺序 --- <sequence></sequence>
引用任何一个元素 --- <any></any>
为element元素添加属性 --- <attribute name="" type=""></attribute>
例如:
<element name="employee">
<complexType>
<sequence>
<any></any>
<element name="name" type="string"></element>
</sequence>
<attribute name="age" type="int"></attribute>
</complexType>
</element>

    2) 为schema定义元素指定名称空间 URI (URI可以是任何路径)--- targetNamespace="http://www.itcast.cn/books"
  ----- 想让xml实例使用schema中定义的元素,需为定义的元素指定名称空间

3、在xml实例数据文件中 ,引用自定义Schema --- xmlns="http://www.itcast.cn/books"

4、声明xml文件是一个应用了schema技术的实例 --- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

5、指定schema文件的位置 --- xsi:schemaLocation="名称空间 schema文件位置" --- xsi:schemaLocation="http://www.itcast.cn/books books.xsd"

注解

elementFormDefault="unqualified"

1、如果schema 将 elementFormDefault="unqualified" ,xml 实例文档 引用名称空间必须使用前缀 ---- 前缀修饰根元素

2、当前xml实例文档所有子元素必须不能用前缀

elementFormDefault="qualified"

1、xml 实例文档 所有元素 要么都用前缀,要么都不用前缀

2、一般我们都使用qualified

名称空间 作用 --- 唯一标识schema当中定义元素

注意:名称空间的名字语法容易让人混淆,尽管以http://开始,但是那个URL并不指向一个包含模式定义的文件。

       事实上,这个URL:http://www.itcast.cn根本没有指向任何文件,只是一个分配的名字
  名称空间可以使用任意的字符串,但是习惯上我们是使用http://前缀的。

简单元素 直接编写type属性 、复杂元素 <complexType> 

代码示例:

books.xsd:

<?xml version="1.0" encoding="UTF-8"?>
<schema xmlns="http://www.w3.org/2001/XMLSchema"
targetNamespace="abcdefg"
elementFormDefault="qualified"
>
<!-- 每一个元素 对应 element -->
<element name="books">
<!-- 包含子元素和属性的元素  复杂元素 -->

<complexType>
<!-- 强调子元素出现顺序 -->
<sequence>
<!-- 让book元素出现多次 *  -->
<element name="book" minOccurs="0" maxOccurs="unbounded">
<complexType>
<sequence>
<!-- 对于简单元素,编写type属性  -->
<element name="name" type="string"></element>
<element name="price" type="double"></element>
</sequence>
</complexType>
</element>
</sequence>
</complexType>
</element>
</schema>


books.xml:

<?xml version="1.0" encoding="UTF-8"?>
<abc:books xmlns:abc="abcdefg"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="abcdefg books.xsd"
>
<abc:book>
<abc:name>Core Java</abc:name>
<abc:price>100</abc:price>
</abc:book>
<abc:book>
<abc:name>think in java</abc:name>
<abc:price>90</abc:price>
</abc:book>
</abc:books>


company.xsd:

<?xml version="1.0" encoding="UTF-8"?>
<schema xmlns="http://www.w3.org/2001/XMLSchema"
targetNamespace="http://www.example.org/company"
elementFormDefault="qualified">
<element name="company">
<complexType>
<sequence>
<element name="employee">
<complexType>
<sequence>
<!-- 引用任何一个元素 -->
<any></any>
<!-- 员工名称 -->
<element name="name">
<complexType>
<simpleContent>
<extension base="string"></extension>
</simpleContent>
<attribute name="salary" type="double"></attribute>
</complexType>
</element>
</sequence>
<!-- 为employee元素添加属性 -->
<attribute name="age" type="int"></attribute>
</complexType>
</element>
</sequence>
</complexType>
</element>
</schema>
department.xsd:

<?xml version="1.0" encoding="UTF-8"?>
<schema xmlns="http://www.w3.org/2001/XMLSchema"
targetNamespace="http://www.example.org/department"
elementFormDefault="qualified">
<!-- 部门名称 -->
<element name="name" type="string"></element>
</schema>


company.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!-- 数据文件 引用多个Schema -->
<company xmlns = "http://www.example.org/company"
xmlns:dept="http://www.example.org/department"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.example.org/company company.xsd http://www.example.org/department department.xsd"
>
<employee age="30">
<!-- 部门名称 -->
<dept:name>人力资源部</dept:name>
<!-- 员工名称 -->
<name salary="3000">王晓晓</name>
</employee>
</company>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: