PHP解析带CDATA的XML方法

XML文件,如下
<xml>
  <ToUserName><![CDATA[toUser]]></ToUserName>
  <FromUserName><![CDATA[FromUser]]></FromUserName>
  <CreateTime>123456789</CreateTime>
  <MsgType><![CDATA[event]]></MsgType>
  <Event><![CDATA[subscribe]]></Event>
  </xml>

假设$str的内容就是上面这段XML。 

1、解决思路很简单:先去掉”cdata”,然后直接转化为json,然后再解析json,然后直接取对应字符串的值,代码如下:

1
​​$obj = simplexml_load_string($str, 'SimpleXMLElement', LIBXML_NOCDATA);​​
$eJSON = json_encode($obj);
 $dJSON = json_decode($eJSON);
 $toUserName = $dJSON->ToUserName;//获取"ToUserName"对应的值

 2、使用$result = getElementByTagName("rule")读取文本,再使用str_replace()用空格替换<![CDATA[( && )]]>,最后使用trim(string,charlist)[charlist=""]删除字符串两端的空格!

posted @   mingruqi  阅读(286)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
历史上的今天:
2021-10-29 python 的 flask 、django 、tornado 、sanic
点击右上角即可分享
微信分享提示