我的学习之路_第十六章_xml

【XML】

可扩展的标记语言

作用:存放数据、配置文件

【XML的语法】

xml的文件扩展名必须为: xml

xml的内容必须满足以下要求:

1.固定的文档声明
2.合格的元素和属性
3.正确的注释
4.符合要求的特殊字符编写规则

●文档声明 ( <?xml version="1.0" encoding = "UTF-8" ?> )

1.文档声明必须以<?xml 开头, 以?>结束
2.文档声明必须从文档的0行0列位置开始
3.文档声明的两个属性:
a. version: 指定的xml文档版本.必须属性
b. encoding: 指定当前文档的编码. 可选属性,默认值为:UTF-8

●元素 <bean> </bean>

1.元素是xml文档中重要的组成部分,
2.普通元素的结构开始标签、元素体、结束标签组成.
3.元素体:元素体可以是元素,也可以是文本.
4.空元素:空元素只有开始标签,没有结束标签,但元素必须自己闭合.<a/>
5.元素命名:
a) 区分大小写
b) 不能使用空格键,不能使用冒号
c) 不建议以xml开头,不管大写还是小写.
6.格式良好的xml文档,必须只有一个根元素.(文档声明下来的第一个元素就是根元素)

●属性(attribute)
<Person id="g001" name="二狗" ></Person>
1.属性是元素的一部分,必须出现在元素开始标签中,必须用空格分开,多个元素之间也用空格隔开
2.属性的定义格式:属性名=属性值,其中属性值必须用单引或者双引
3.一个元素可以有0-n个属性,但是一个元素中,不能出现同名属性
4.属性名不能使用空格,冒号等特殊符号,而且必须以字母开头
5.多个属性之间没有先后顺序

●注释

xml的注释,以<!-- 开始, 以--> 结束.注释内容不会被xml解析器解析!

【xml的转义字符】

< &lt;

> &gt;

" &quot;

' &apos;

& &amp;

列入 1<3 在xml中 1 &lt;3

【CDATA】

格式 <![CDATA[

里面可以写任何内容,
都会以文本的格式出现
里面的出现的字符都无需转义

]]>

作用:提高了xml文档的可读性

【XML约束】

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

常见的约束有 DTD , Schena

DTD语法:

▲ 文档声明
1.内部DTD,在xml文档内部嵌入,值对当前xnl有效
2.外部DTD- 本地DTD,DTD文档在本地系统上,公司内部自己项目使用.(SYSTEM )
3.外部DTD- 公共DTD,DTD文档在网络上,一般都有框架提供(PUBLIC )

公共DTD包含5部分内容:
1.<!DOCTYPE:固定格式
2.beans : 规定根元素叫beans
3.PUBLIC : 公共的,说明DTD 约束文档来源网络
4."-//SPRING//DTD BEAN 2.0//EN": 约束文档的名称,有框架写好提供.
5.http://www.springframework.org/dtd/spring-beans-2.0.dtd:约束文档在网络上的位置

▲ 元素申明

? 表示该对象可以出现0次或者1次,
+ 表示该对象可以出现1次或者1次以上
* 表示可以出现任意次数
( ) 一组数据
| 选择关系,只能在多个元素之间选择一个
, 顺序关系,规定:a,b,c 写xml文档只能按照abc顺序编写

【使用DTD约束文档的步骤】

1.每一个DTD约束文档中都会有一行代码以 <!DOCTYPE开头,赋值过来放在xml文档中
a.!DOCTYPE : 固定的DTD约束文档的格式
b.beans : 规定xml文档中的根元素只能叫beans
c.SYSTEM : 系统, dtd约束文档中来源本地的操作系统
d: "bean.dtd" : 约束文档的位置,我们使用的约束文档在当前文件夹下,可以使用"bean,dtd"
2.根据根元素的名字,写出根元素
3.鼠标放在根元素上/或者按F2,根据提示写出xml文档

Schema约束

▲命名空间

命名空间是用来处理元素和属性的名称冲突问题

约束文档和xml的关系
约束 约束
官方文档---->自定义schema文档---->xml文档

声明命名空间:

默认命名空间:<xxx xmlns=" " >, 使用<标签>
显式命名空间:<xxx xmlns:别名=" "> , 使用<别名:标签>

【Schema 约束文档的使用】:

1.每一个schema约束文档,都必须有一个命名空间(namespace)
起名要求:全球唯一
使用域名(网址) 命名:http://www.itcast.cn/web01/01
bean-schema.xsd文档中的命名空间
targetNamespace="http://itcast.cn/bean"
2.在xml文档中声明命名空间
默认声明:
xmlns="http://www.itcast.cn/bean"
<bean></bean>
显示声明:
xmlns:my="http://www.itcast.cn/bean"
<my:bean></my:bean>
3.声明schema约束文档的位置
先声明官方文档的位置
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
根据官方文档声明自定义schema文档的位置
xsi:chemaLocation="http://www.itcast.cn/bean bean-schema.xsd"
http://www.itcast.cn/bean : 命名空间
bean-schema.xsd:schema文档的位置

【XML解析】

开发中比较常见的解析方式有三种:
1.DOM : 要求解析器把整个xml文档装载到内存,并解析成一个Document对象
a) 优点 : 元素与元素之间保留结构关系,所以可以进行增删改查操作.
b) 缺点 : xml文档过大,可能出现内存溢出显示
2.SAX : 是一种速度更快,更有效的方法.它逐行扫描文档,一边扫描一边解析
a) 优点 : 处理速度快,可以处理大文件
b) 缺点 : 只能读,逐行后将释放资源.
3.PULL : Android内置的xml解析方式,类似sax.
SAX(推): 就像一座山,逐层推掉,想要的保留下来,不想要的就扔掉.
PULL(拉) : 把想要的数据拉过来,不需要的数据连拉都不拉,直接扔掉

常见的解析发开包:

● JAXP: sum公司提供支持DOM和SAX开发包

● JDom: dom4j兄弟

● jsoup: 一种处理 HTML特定解析开发包

● dom4j: 比较常见的解析开发包,hibernate底层采用(主要用这个)

【使用dom4j解析xml文档】

1.SAXReader对象(dom4j核心类)
利用方法 read(...)加载执行xml文档
2.Document对象
返回值 Element getRootElement() 获取根元素
3.Element对象
返回值 Element[] elements(...) 获取的指定名称的所有元素.可以不指定名称
element(...) 获得指定名称第一个子元素,可以不指定名称
getName() 获得当前元素的元素名
attributeValue(...) 获得指定属性名的属性值
elementText(...) 获得指定名称子元素的文本值
getText() 获得当前元素的文本内容

时间: 2025-01-18 11:08:34

我的学习之路_第十六章_xml的相关文章

我的学习之路_第二十六章_javaScript(2)

Javascript [DOM操作] 获取元素 var obj = document.getElementById("id值"); 获取值 obj.value; 设置值 obj.value=值; 获取标签体内容 obj.innerHtml; 设置标签体内容 obj.innerHtml=值; 使用正则表达式校验数据 1.编写正则表达式 1.用户名的正则 : /^[a-z0-9_-]{3,16}$/ 2.密码:/^[a-z0-9_-]{6,18}$/ 3.电子邮箱:/^([a-z0-9_\

我的学习之路_第二十二章_事务

JDBC事务 [事务] 作用: 保证多条SQL语句,要么都执行成功,要么都执行失败. mysql数据库,执行SQL语句,自动开启事务,提交事务,回滚事务,把数据永久保存 oracle数据库,执行SQL语句,手动开始会务,提交事务,回滚事务,把数据永久保存. Connection接口中和事务有关的方法: 无返回值 setAutoCommit(boolean autoCommit) 将此连接的自动提交模式设置为给定状态. 参数:autoCommit : true表示自动提交模式, false表示禁用

我的学习之路_第二十九章_bootstrap

bootstrap 内置了html,css,js插件为一体的前端框架 响应式布局: 设计一套页面就可以使用于很多现实设备 bootstrap: 1.入门(响应式布局的容器) 1.先进入jQuery的js2.再引入bootstrap的js3.引入bootstrap的css文件4.设置视口(支持移动设备优先) <meta name="viewport" content="width=device-width,initial-scale=1"> 5.页面创建一

我的学习之路_第十四章_反射

类的反射 [获取class文件对象的三种方式]: ● 使用Object类中的方法 getClass() Class<?> getClass() 返回此Object的运行时类. ● 使用类名.class属性 每一个数据类型,基本数据类型和引用数据类型,Java都会为其设置一个class属性 例如: Class class = int.class Class class = String.class Class class = Person.class● 使用Class类中的静态方法forName

我的学习之路_第十八章_SQL语句

SQL语句 启动数据库: net start mysql 关闭数据库: net stop mysql 登录数据库 : cmd-->命令行-->mysql-->mysql -u账号 -p密码 [创建和删除数据库] 使用关键字 : create(创建) database(数据库) 格式: create database 数据库名; create database 数据库名 character set 字符集; ●--查看mysql中所有的数据库 show database; ●--查看某个数

我的学习之路_第二十八章_JQuery 和validator插件

jQuery 利用jQuery进行遍历 js原生: for(var i=0;i>?;i++){ } jQuery: 方式一: 想要遍历的jQuery对象.each(function(index,dom){ }); 方式二: $.each(想要遍历的jQuery对象,function(index,dom){ }); 操作元素的值或者标签体 xxx():获取操作 xxx("值"):设置 获取或设置值: val(); 获取或设置标签体: html() 获取或设置标签体: text()

算法导论_第十六章_动态规划_creatshare分享会

动态规划 注:该篇为本人原创,转载请注明出处:http://blog.csdn.net/chudongfang2015/article/details/51590817--开心 -.- 个人对动态规划的理解: 1.动态规划是一个付出额外空间来节省时间,就是所谓的空间换时间. 2.动态规划储存每个状态的最优解. 3.动态规划是用来把子问题的结果储存下来,再次用到的时候就不必再进行重复计算. 算法导论对动态规划的解释: 动态规划和分治方法相似,都是通过组合子问题的解来求解原问题,分治方法将问题划分为

《Python 学习手册4th》 第十六章 函数基础

''' 时间: 9月5日 - 9月30日 要求: 1. 书本内容总结归纳,整理在博客园笔记上传 2. 完成所有课后习题 注:“#” 后加的是备注内容 (每天看42页内容,可以保证月底看完此书) “重点笔记”“本章习题” - 标题1,二级标题用- 标题2,笔记大纲标题.习题题目- 加粗,16px ''' 重点笔记 摘要 函数是Python为了代码最大程度的重用和最小化代码冗余而提供的最基本的程序结构.一. 为何使用函数 最大化的代码重用和最小化代码冗余 流程的分解 本章习题: 1. 编写函数有什么

Python之路【第十六篇】:Django【基础篇】

Python之路[第十六篇]:Django[基础篇] Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. 基本配置 一.创建django程序 终端命令:django-admin startproject sitename IDE创建Django程序时,本质上都是自动执行上述命令 其他常用命令: python manage.py runserver