什么是XML
特点
声明
元素/节点
(1)根节点: 有且只有一个根元素
(2)子节点: 可以嵌套,可以重复
(3)每个节点必须成对出现,空节点也必须成对出现
属性
(1)每个元素/节点可以有多个属性
(2)属性以键值对的方式出现:名称=“值”。属性的值添加双引号,多个属性以空格分开。
注释:
DTD全称是The document type definition,即是文档类型定义,可定义合法的XML文档
它使用一系列合法的元素来定义文档的结构。DTD可以被成行的声明于XML
1.一个应用程序keyishiyongDTD来确认收到的XML数据是有效的
2.每一个XML文件可以携带一个自身格式的描述
3.不同组织的人可以使用一个通用DTD来交换数据
DTD分为:内部DTD、外部DTD、共有DTD
都为DTD
外部DTD
可以看出把DTD写到了"note.dtd"中
共有DTD
实体的概念:实体是用于定义引用普通文本或特殊字符的快捷方式的变量。实体引用是对实体的引用。
实体可在内部或外部进行声明。
分类:内部实体,外部实体、参数实体
声明一个元素 | ||
---|---|---|
空元素 | EMPTY> | |
只有PCDATA的元素 | ||
带任何内容的元素 | ||
带有子元素(序列)的元素 |
利用xxe漏洞可以进行拒绝服务攻击(DDos),文件读取,命令(代码)执行,SQL(XSS)注入,等
一般的xml:
第一部分:XML声明部分
第二部分:文档类型定义 DTD
]>
第三部分:文档元素
nuc
grade20
2013040212
wpp
进入pikachu靶场
提交一个xml
]> &hack;
外部实体引入攻击载荷使其访问host文件
]>
&f;
再来一个,我们这次访问win.ini
]>
&xxe;