php cdata解析,PHP cdata 处理(详细介绍)

// States:

//

//     ‘out‘

//     ‘

//     ‘

//     ‘

//     ‘

//     ‘

//     ‘

//     ‘

//     ‘in‘

//     ‘]‘

//     ‘]]‘

//

// (Yes, the states a represented by strings.)

//

$state = ‘out‘;

$a = str_split($xml);

$new_xml = ‘‘;

foreach ($a AS $k => $v) {

// Deal with "state".

switch ( $state ) {

case ‘out‘:

if ( ‘

$state = $v;

} else {

$new_xml .= $v;

}

break;

case ‘

if ( ‘!‘ == $v  ) {

$state = $state . $v;

} else {

$new_xml .= $state . $v;

$state = ‘out‘;

}

break;

case ‘

if ( ‘[‘ == $v  ) {

$state = $state . $v;

} else {

$new_xml .= $state . $v;

$state = ‘out‘;

}

break;

case ‘

if ( ‘C‘ == $v  ) {

$state = $state . $v;

} else {

$new_xml .= $state . $v;

$state = ‘out‘;

}

break;

case ‘

if ( ‘D‘ == $v  ) {

$state = $state . $v;

} else {

$new_xml .= $state . $v;

$state = ‘out‘;

}

break;

case ‘

if ( ‘A‘ == $v  ) {

$state = $state . $v;

} else {

$new_xml .= $state . $v;

$state = ‘out‘;

}

break;

case ‘

if ( ‘T‘ == $v  ) {

$state = $state . $v;

} else {

$new_xml .= $state . $v;

$state = ‘out‘;

}

break;

case ‘

if ( ‘A‘ == $v  ) {

$state = $state . $v;

} else {

$new_xml .= $state . $v;

$state = ‘out‘;

}

break;

case ‘

if ( ‘[‘ == $v  ) {

$cdata = ‘‘;

$state = ‘in‘;

} else {

$new_xml .= $state . $v;

$state = ‘out‘;

}

break;

case ‘in‘:

if ( ‘]‘ == $v ) {

$state = $v;

} else {

$cdata .= $v;

}

break;

case ‘]‘:

if (  ‘]‘ == $v  ) {

$state = $state . $v;

} else {

$cdata .= $state . $v;

$state = ‘in‘;

}

break;

case ‘]]‘:

if (  ‘>‘ == $v  ) {

$new_xml .= htmlentities($cdata);

#       $new_xml.= $cdata;

//                        $new_xml .= str_replace(‘>‘,‘>‘,

//                                  str_replace(‘>‘,‘

//                                str_replace(‘"‘,‘"‘,

//                              str_replace(‘&‘,‘&‘,

//                            $cdata))));

$state = ‘out‘;

} else {

$cdata .= $state . $v;

$state = ‘in‘;

}

break;

} // switch

}

//

// Return.

//

return $new_xml;

最近发现,总是有alert发出来, 说是simplexml解析出错。

发现是原来有xml的数据是. 出现了连续的3个], 造成上面的解析函数不能处理。

而且这个问题很难修正, 你不知道下次会不会有4, 5个]出现。

所以决定还是将这段解析 的代码换成DOM XML,本身 DOM的处理还是比较简单的,

包含DOMElement, DOMDocument, DOMNodeList, DOMNode几个 component.

对于 DOMNode有nodeValue, nodeType, nodeName的成员函数。

首先先用loadXML将string转化为DOMDocument对像, 再用getElementsByTagName转化为DOMNodeList对像, 再使用->item(0)转化为DOMNOde, 然后就可以使用上面的三种方法了。

对于 test这种xml标签, 要使用 attribute函数。

原文:http://www.jb51.net/article/39537.htm

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值