首页 > 代码库 > XML
XML
1 XML 2 * extensible Markup Languae :可扩展标记型语言 3 ** 标记型语言:html是标记型语言 4 - 也是使用标签来操作 5 ** 可扩展: 6 - html里面的标签是固定的,每个标签都有特定的含义<h1><br/><hr/> 7 - 标签可以自定义,可以写中文的标签<person></persn> <猫></猫> 8 * xml用途 9 ** html适用于显示数据,xml也可以显示数据(不是主要功能) 10 ** xml只要功能,为了存储数据 11 12 * xml是w3c组织发布的技术 13 * xml有两个版本:1.0 1.1 14 -使用1.0版本:(1.1版本不能向下兼容)。 15 * xml的应用 16 * 不同的系统之间传输 17 ** qq之间数据传输 18 * 用来表示生活中有关系的数据 19 * 经常用在来配置文件 20 21 * xml语法 22 (1)xml的文档声明 23 * 创建文件,后缀为.xml 24 * 如果写xml 第一步必须要有一个文档声明(写了文档声明之后,表示写xml文件) 25 ** <?xml version="1.0" encoding="GBK"?> 26 ** 文档声明必须写 第一行 第一列 27 * 属性 28 - version: xml的版本1.0(使用1.0) 29 - encoding:xml编码 gbk utf-8 iso8859-1(不包含中文) 30 - standalone: 是否需要依赖其他文件 yes/no 31 - xml的中文乱码 计算机默认保存时gbk 自己定义时utf-8就会乱码 应该在保存时改掉计算机默认为设置的编码 32 (2)定义元素(标签) 33 (3)定义属性 34 (4)特殊字符 35 (5)注释 36 (6)CDATA区 37 (7)PI指令 38 5*xml的元素定义: 39 ** 标签定义: 40 ** 有开始有结束<person></person> 41 ** 可以再内部结束<person /> 42 ** 标签可以嵌套,必须要合理: 43 ** 合理嵌套<bb><aa></aa></bb> 44 ** 只能有一个根标签,其他的都是子标签 45 ** 空格和内容都会解析:不能写空格 46 ** xml标签可以使中文 47 48 ** xml中标签的名称规则 49 (1)xml代码区分大小写 50 (2)xml的标签不能以xml开头 51 (3)xml不能以数字下划线开头 52 (4)xml不能包含空格和冒号 53 54 * xml照片那个特殊字符 55 ** 小于号:< 56 ** 大于号:> 57 ** 双引号:" 58 ** 单引号:&apos 59 ** & :& 60 61 * CDATA区: 62 ** 可以解决多个字符都需要专一的操作 63 ** 把这些内容放在CDATA中不需要转义; 64 ** 写法:就是把特殊字符当成文本内容显示出来 65 ** <![CDATA][内容]]> 66 67 * PI指令(处理指令) 只对应为标签起做用 68 ** 可以再xml中设置效果 69 ** 导入css写法: <?xml-stylesheet type="text/css" href="http://www.mamicode.com/路径" ?> 70 71 * xml约束: 72 ** 一个dad约束 一个schema约束 73 *** dtd快速入门 74 * 创建文件 后缀: .dtd 75 * 步骤; 76 * 有多少元素 就在dtd中创建几个<!ELEMENT> 77 * 判断元素是简单元素还是复杂元素 78 - 简单元素:没有子元素 79 <!ELEMENT 元素名称(#PCDATA) > 80 - 复杂元素:有子元素的元素 81 <!ELEMENT 元素名称(子元素名称) > 82 * 将dtd引入xml中方法 83 * <!DOCTYPE 元素名称 SYSTEM "dtd路径"> 84 ** dad三种引入方式; 85 (1) 引入外部dtd文件 86 <!DOCTYPE 元素名称 SYSTEM "路径"> 87 (2) 内不直接写; 88 <!DOCTYPE 元素名称 [ 89 - 简单元素:没有子元素 90 <!ELEMENT 元素名称(#PCDATA) > 91 - 复杂元素:有子元素的元素 92 <!ELEMENT 元素名称(子元素名称) > 93 94 ]> 95 (3) 使用外部dtd文件(网络上的) 96 <!DOCTYPE 根元素 PUBLIC "DTD名称" "dtd文档路径URL"> 97 在后面学到的 框架中 struts2中学到 使用配置文件用 98 * 使用dtd定义元素 99 *简单元素:没有子元素的元素100 <!ELEMENT name (#PCDATA)>101 *** (#PCDATA);约束那么是字符串类型102 *** EMTY: 元素为空 (没有内容)103 *** ANY:任意104 * 复杂元素:105 <!ELEMENT person (name,age)>106 -子元素只能出现一次107 ** 表示元素出现的次数;108 +: 表示一次或多次109 ?: 表示零次或一次110 *: 表示出现任意次数 (有没有都行)111 **子元素之间用 , 号隔开,表示元素出现的顺序.112 **子元素之间用 | 号隔开,表示元素出现的顺序.113 114 * 使用dtd定义属性115 * 语法: <ATTLIST 元素名称116 属性名称 属性类型 属性的约束117 >118 * 属性类型119 - CDATA :字符串120 - <!ATTLIST birthday121 ID1 CDATA #REQUIRED122 >123 - 枚举: 表示只能在一定的范围内出现值,但是只能每次出现其中一个.124 ** 红绿灯效果125 ** (aa|bb|cc)126 - <!ATTLIST age127 ID2 (AA|BB|CC) #REQUIRED128 >129 ID :值只能是字母或者下划线开头130 * 属性的约束 <!ELEMENT ><age ID="DDD">20</age>131 - #REQUIRED ;表示必须有132 - #IMPLIED;表示可有可无133 - #FIXED :表示一个固定值, #FIXED "AAA"134 - 属性的值必须是设置的这个固定值135 - <!ATTLIST sex 136 ID4 CDATA #FIXED "ABC"137 >138 - 直接值:139 * 不写属性,使用直接值140 * 写了属性,使用设置那个值141 -<!ATTLIST school142 ID5 CDATA "DDD"143 >144 * 定义实体:145 * 语法: <!ENTITY 实体名称 "实体的值">146 ** 定义实体<!ENTITY TEST "HAHAHA">147 ** 使用实体 &实体名称; 比如: &TEXT;148 149 ** 特别注意:150 * 定义的实体需要写在内部的dtd里面151 152 * schema约束:153 ** dtd语法: <!ELEMENT 元素名称 约束>154 ** schema符合xml的语法,xml语句:155 ** 一个xml中可以有多个schema,多个schema使用名称空间来区分(类似于java中的包)156 ** dtd里面有PCDATA类型.但是schema里面可以支持更多的数据类型 157 *** 比如 年龄 只能是整数 在schema可以直接定义一个整数类型158 **语法更加复杂,所以schema目前不能替换dtd.159 * schema的快速入门160 *后缀名为 .xsd161 * 创建一个schema文件162 ** 根节点就是<schema>163 * 在schema文件中164 ** 属性 xmlns="http://www.w3.org/2001/XMLSchema"165 - 表示当前xml问价是一个约束文件‘166 ** targetNmaespace="http://www.itcast/cn/20151111"167 - 使用schema约束文件,直接通过这个地址引入约束文件168 ** elementFormDefault="qualified"169 * 步骤:170 (1) 看xml中有多少元素171 <element>172 (2) 看简单元素和复杂元素173 - 复杂元素;174 ** <complexType>175 <sequence>176 子元素177 </sequence>178 </complexType>179 - 简单元素,卸载复杂元素的中间180 <element name="person">181 <complexType>182 <sequence>183 <element name="name" type="string"></element>184 <element age="age" type="int"></element>185 </sequence>186 </complexType>187 </element>188 (3) 在约束文件里面引入约束文件189 <person xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"190 xmlns="http://www.itcast.cn/20151111"191 xis:schemaLocation="http://www.itcast.cn/20151111 1.xsd">192 193 **解释:194 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"195 - 表示xml是一个被约束的文件196 xmlns="http://www.itcast.cn/20151111"197 - 是约束文档里面targetNmaespace198 xis:schemaLocation="http://www.itcast.cn/20151111 1.xsd"199 - targetNmaespace+空格+约束文档的地址200 * schema复杂元素指示器201 * <sequence>:表示元素的出现顺序202 * <all> 元素只能出现一次203 * maxOccurs="unbounded":表示元素的出现次数204 * <any></any>:表示任意元素205 * 可以约束属性206 * 写在复杂元素里面;207 * 写在 <complexType>之前208 --- 209 <attribute name="id1" type="int" use="required">210 -- name :属性名称211 -- type: 属性类型 int string212 -- use :属性是否必须出现 required213 214 215 216 * XML解析简介(写java代码)***217 * xml是表机型文档218 * 就是使用dom解析表机型文档219 - 根据html的层级结构,在内存中分配一个树形结构.把html的标签,属性和文本都封装成对象.220 - document对象,element对象.属性对象.node节点对象;221 * xml的解析就是dom和sax方法222 * dom层级结构解析,在内存中分配一个树形结构,吧xml的标签,属性文本都会封装成对象.223 优点:可以增删改操作224 缺点:文件过大时会内存溢出225 * sax一行一行从上往下边读边解析:226 优点:不会内存溢出.227 缺点:不能增删改.228 ** 不同的公司对dom和sax技术用不同的解析器:229 - sun公司提供的是dom和sax解析器: jaxp230 - dom4j组织,针对dom和sax解析器: dom4j(经常用)231 - jdom组织,针对dom和sax解析器: jdom232 233 234 * jaxp的api的查看;java代码 不能使用var了 使用的是w3才包235 ** jaxp是Javase的一部分236 ** jaxp解析器在jdk的javax.xml.parsers包里面237 ** 四个类; 分别是针对dom和sax解析使用类238 document:操作:239 查询:240 步骤:241 1.创建解析器工厂242 2.根据解析器工厂创建解析器243 3.解析xml,返回document244 4.得到所有neam元素245 5.使用返回集合里面的方法item(),下标获取具体元素246 NodeList.item(i);集合下标i从0开始247 6.得到具体的值,使用getTextContent方法
XML
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。