JavaEE实战——XML语法和约束技术
Posted 李春春_
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaEE实战——XML语法和约束技术相关的知识,希望对你有一定的参考价值。
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 templatesctrl+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语法规范
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.xml2、编写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 bookbid 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快速入门
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>
以上是关于JavaEE实战——XML语法和约束技术的主要内容,如果未能解决你的问题,请参考以下文章