首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

PHP解析Xml:SimpleXML类学习笔记

SimnnpleXML 1.介绍 SimpleXML 是 PHP 5 中的新特性。SimpleXML 扩展提供了一种获取 XML 元素的名称和文本的简单方式。...SimpleXML 可把 XML 文档(或 XML 字符串)转换为对像; 元素被转换为 SimpleXMLElement 对象的单一属性。当同一级别上存在多个元素时,它们会被置于数组中。...属性通过使用关联数组进行访问,其中的索引对应属性名称。 元素内部的文本被转换为字符串。如果一个元素拥有多个文本节点,则按照它们被找到的顺序进行排列。...simplexml_load_string() 转换 XML 字符串为 SimpleXMLElement 对象。 attributes() 返回 XML 标签的属性和值。...children() 查找指定节点的子节点。 count() 计算指定节点的子节点个数。 getName() 返回 SimpleXML 元素引用的 XML 标签的名称。

97150
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    XML

    -- 注释内容 --> XML属性: 描述其本身额外的信息 如 属性规则:一个标签可有多个属性 属性必须使用引号 命名规则与变量名规则差不多...不过属性用到的地方不多 XML不将数据解析 在有些时候我们可能要使用很多的特殊字符,但是你又不想使用类似于<的转义字符,这里我们就可以用“CDATA”数据区域 “CDATA”不会将区域内的内容解析...在php5版本后,为我们提供了一个非常强大的类库,SilpmeXML专门用于实现XML文档的解析操作 使用函数simplexml_load_file(path); 解析XML文件,返回php对象 //...Xpath是专门用来查找XML数据内容的一种规则 用来在XML文档中对元素及属性进行遍历 xpath(path) 查找语法 绝对路径查找 如下XML数据 ...返回数组类型,数组值为属性->值 其他查找 last()查找最后一个 返回值与条件查找的返回值一样 $xmlObj=simplexml_load_string($xml,'SimpleXMLElement

    1.7K20

    XXE注入漏洞

    XML 很像HTML,但是标签大小写敏感,且没有被预定义,需要自行定义标签,必须按顺序闭合标签,必须含有根元素,属性值须加引号。 它的文档结构包括XML声明、DTD文档类型定义(可选)、文档元素。...它使用一系列的合法元素来定义文档结构。可以嵌入在XML文档中(内部声明),也可以独立的放在一个文件中(外部引用)。如同html里的js一样,可以放在html页面里,也可以是单独的一个文件。...DTD文档组成 1.元素(ELEMENT)的定义规则; 2.元素之间的关系规则; 3.属性(ATTLIST)的定义规则; 4.可使用的实体(ENTITY)或符号(NOTATION)规则。...load=%load;'>" > %all; 3.加载load.xml文件后,执行all实体的时候,又执行load实体,并赋值给load(即%load的运行结果赋给load) 4.然后返回zz.php文件...,再加载send实体,即运行load.xml里内置的send规则实体,加载test.php里的内容 test.php <?

    2.7K32

    干货 | 一文讲清XXE漏洞原理及利用

    XXE漏洞 XXE全称为XML External Entity Injection即XMl外部实体注入漏洞 XXE漏洞触发点往往是可以上传xml文件的位置,没有对xml文件进行过滤,导致可加载恶意外部文件和代码...xml文档的构建模块 所有的 XML 文档(以及 HTML 文档)均由以下简单的构建模块构成: 元素 属性 实体 PCDATA CDATA 下面是每个构建模块的简要描述。 1....元素 元素是 XML 以及 HTML 文档的主要构建模块,元素可包含文本、其他元素或者是空的。...属性 属性可提供有关元素的额外信息 实例: 3. 实体 实体是用来定义普通文本的变量。实体引用是对实体的引用。 4....XML语法规则 所有XMl元素必须有一个闭合标签 XMl标签对大小写敏感 XMl必须正确嵌套 XML属性值必须加引号 实体引用 在XMl中,空格会被保留 函数介绍 file_get_cintent函数介绍

    15.3K21

    php开发微信公众号步骤_微信公众平台php对接

    微信发送的消息格式都是 XML 格式,你返回的消息也必须是 XML 格式。从 XML 里提取数据,用 SimpleXML,强大又容易使用。包装成 XML 消息呢?...解析POST过来的XML数据 postObj = simplexml_load_string(postStr,’SimpleXMLElement’,LIBXML_NOCDATA); fromUsername...xml 格式或者 json 格式,处理时用 SimpleXML 和 json_decode 是很方便的。...不过也引入了一些新的问题,比如页面内 CSS 和 Javascript 的加载,因为 Jquery Mobile 默认是使用 Ajax 加载页面的,并不会刷新整个 html ,而是请求一个 page 而已...,所以对于多个 page 的页面不会完全加载,对于 head 里面的 CSS 和 Javascript 也不会加载,所以一个方法是在链接的属性里设置 ajax=false,指明不通过 Ajax 加载页面

    16.4K30

    XXE攻击与防御

    前段时间比较出名的微信支付的xxe漏洞 漏洞简历 XXE就是XML外部实体注入,当服务器允许引用外部实体时,同过构建恶意内容来攻击网站 产生原因 解析xml文件时允许加载外部实体,并且实体的URL支持file...DOCTYOE 根元素 [元素声明]> xml version='1.0' encoding="utf-8" ?> 的数据,存入 $xml simplexml_load_string 函数介绍 php 中的 simplexml_load_string...type=3 站长工具 利用kali解密 在Kali中使用base64进行解密获取文本内容 利用burpsuite解密 对于小白不会用burp suite的情况下,这里博主在啰嗦两句 Decode...server端,来获取校验文件,收到后,我们server端就会返回到服务器当中,当返回dtd这个定义文件后就会在本服务器查询对应的数据,在返回给我们的server端 服务器可以随便选择,这里我用的是kali

    1.4K40

    Xpath学习笔记,持续记录

    使用方法如下: 轴名称::节点测试[谓语] # 选取元素的所有属性 //*[@id="fixed"]/aside/attribute::* //*[@id="fixed"]/aside/@* 5.xpath...()迭代所有元素,一旦迭代完成所有的匹配节点,iterateNext() 将返回 null。...快照不随文档突变而改变,因此与迭代器不同,快照不会变得无效,但是它可能不对应于当前文档,例如节点可能已被移动,它可能包含不再存在的节点,或新节点可能已添加。...对于无序子类型,返回的单个节点可能不是文档顺序中的第一个,但是对于有序子类型,保证以文档顺序获取第一个匹配的节点。 PHP中使用Xpath <?...php $xml = simplexml_load_file("test.xml"); $result = $xml->xpath("from"); print_r($result

    87340

    XML外部实体注入学习

    XXE的利用手法 1.加载恶意外部文件 2.任意读取文件 3.执行系统命令 4.探测内网端口 5.攻击内网网站 怎么说呢只要权限到位几乎都可以做。...-- ⬆文档类型定义(DTD)⬆ --> 元素名称 category="属性"> 文本或其他元素 元素名称> XML文档中(内部声明),也可以独立的放在一个文件中(外部引用),由于其支持的数据类型有限,无法对元素或属性的内容进行详细规范,在可读性和可扩展性方面也比不上XML Schema。...实体的概念就是在XML文档种频繁的使用某一条数据,我们可以预先给这个数据起一个别名,也就是一个ENTITY,之后再在文档种调用它。 在引用DTD实体时有内部声明实体和外部引用实体的区别。...XXE防御 1.使用开发语言提供的禁用外部实体的方法。

    81630

    windows文件读取 xxe_XXE漏洞「建议收藏」

    XML文档结构包括XML声明、DTD文档类型定义(可选)、文档元素。 2.文档结构 XML文档结构包括XML声明、DTD文档类型定义(可选)、文档元素。...这一数据即XML字符串中使用的对象(或者说根元素)的数据,并echo输出出来。...%f; ]> &b; data = simplexml_load_string(xml); print_r($data); 远程服务器的evil.dtd文件内容 blind xxe漏洞方案3: 可以使用外带数据通道提取数据...因此,最好的解决办法就是配置XML处理器去使用本地静态的DTD,不允许XML中含有任何自己声明的DTD。通过设置相应的属性值为false,XML外部实体攻击就能够被阻止。...有很大的可能服务器会解析你异步上传的xml脚本执行想要干的事 解题步骤: 要先修改Content-Type: application/xml 然后加入xml脚本即可 ]> &myentity; 得到返回结果

    2.5K20

    XXE实体注入漏洞详解

    原理 既然XML可以从外部读取DTD文件,那我们就自然地想到了如果将路径换成另一个文件的路径,那么服务器在解析这个XML的时候就会把那个文件的内容赋值给SYSTEM前面的根元素中,只要我们在XML中让前面的根元素的内容显示出来...另外,一般来说,服务器解析XML有两种方式,一种是一次性将整个XML加载进内存中,进行解析;另一种是一部分一部分的、“流式”地加载、解析。...可以嵌入在XML文档中(内部声明),也可以独立的放在一个文件中(外部引用),由于其支持的数据类型有限,无法对元素或属性的内容进行详细规范,在可读性和可扩展性方面也比不上XML Schema。...DTD文档组成 1.元素(ELEMENT)的定义规则; 2.元素之间的关系规则; 3.属性(ATTLIST)的定义规则; 4.可使用的实体(ENTITY)或符号(NOTATION)规则。...寻找XXE 检测xml是否被解析 尝试注入特殊字符,使XML失效,引发解析异常,明确后端使用XML传输数据。 单双引号 ' " :XML的属性值必须用引号包裹,而数据可能进入标签的属性值。

    1.2K20

    微信公众平台开发笔记

    微信发送的消息格式都是 XML 格式,你返回的消息也必须是 XML 格式。从 XML 里提取数据,用 SimpleXML,强大又easy使用。包装成 XML 消息呢?.../获取POST数据 //用SimpleXML解析POST过来的XML数据 $postObj = simplexml_load_string($postStr,'SimpleXMLElement',LIBXML_NOCDATA...xml 格式或者 json 格式,处理时用 SimpleXML 和 json_decode 是非常方便的。...只是也引入了一些新的问题,比方页面内 CSS 和 Javascript 的载入,由于 Jquery Mobile 默认是使用 Ajax 载入页面的,并不会刷新整个 html ,而是请求一个 page 而已...,所以对于多个 page 的页面不会全然载入,对于 head 里面的 CSS 和 Javascript 也不会载入,所以一个方法是在链接的属性里设置 ajax=false,指明不通过 Ajax 载入页面

    2.5K20

    如何使用PHP解析XML大文件

    如果使用 PHP 解析 XML 的话,那么常见的选择有如下几种:DOM、SimpleXML、XMLReader。...如果要解析 XML 大文件的话,那么首先要排除的是 DOM,因为使用 DOM 的话,需要把整个文件全部加载才能解析,效率堪忧,相比较而言,SimpleXML 和 XMLReader 更好些,SimpleXML...下面我以一个 XML 大文件例子来对比一下 SimpleXML 和 XMLReader 的用法: ......> 在本例中,XML 文件有几百万行,XMLReader 的效率是 SimpleXML 的两倍左右。...了解了相关知识,让我们看看如何选择合适的 XML 解析方法:如果规则比较复杂的话, 比如要查询当前节点的上下文,那么 DOM 是合理的选择;如果 XML 体积比较大的话,那么 XMLReader 是效率更高

    3.5K30

    PHP代码审计03之实例化任意对象漏洞

    比如可以使用PHP内置类SimpleXMLElement来进行XXE攻击,看一下PHP手册对这个函数的解释: ? 功能就是用来表示XML文档中的元素。...SimpleXMLElement::addAttribute-向SimpleXML元素添加属性 SimpleXMLElement::addChild-向XML节点添加子元素 SimpleXMLElement...::asXML-基于SimpleXML元素返回格式良好的XML字符串 SimpleXMLElement::attributes-标识元素的属性 SimpleXMLElement::children...::getNamespaces-返回文档中使用的命名空间 SimpleXMLElement::registerXPathNamespace-为下一个XPath查询创建前缀/ns上下文 SimpleXMLElement...这里需要注意一点:要结合PHP流的使用,因为当文件中存在: & ' " 等符号时会导致XML解析错误。我们用PHP流进行base_64编码输出就可以了。 什么是PHP流呢?

    88510

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券