xml json 的解析

1:跟据url得到xml并解析成数组

<?php
/*
描述:将xml文档格式化成一个数组,让你用访问数组的方式来访问xml文档的各个节点,(爽的要死,嘎嘎!)
@xml: 传进去的xml格式的字符串(自己验证一下xml格式要标准)
@return : 返回一个数组
*/
function xml2array($xml) {

        $xmlary = array();
                
        $reels = '/<(\w+)\s*([^\/>]*)\s*(?:\/>|>(.*)<\/\s*\\1\s*>)/s';
        $reattrs = '/(\w+)=(?:"|\')([^"\']*)(:?"|\')/';

        preg_match_all($reels, $xml, $elements);

        foreach ($elements[1] as $ie => $xx) {
                $xmlary[$ie]["name"] = $elements[1][$ie];
                
                if ($attributes = trim($elements[2][$ie])) {
                        preg_match_all($reattrs, $attributes, $att);
                        foreach ($att[1] as $ia => $xx)
                                $xmlary[$ie]["attributes"][$att[1][$ia]] = $att[2][$ia];
                }

                $cdend = strpos($elements[3][$ie], "<");
                if ($cdend > 0) {
                        $xmlary[$ie]["text"] = substr($elements[3][$ie], 0, $cdend - 1);
                }

                if (preg_match($reels, $elements[3][$ie]))
                        $xmlary[$ie]["elements"] = xml2array($elements[3][$ie]);
                else if ($elements[3][$ie]) {
                        $xmlary[$ie]["text"] = $elements[3][$ie];
                }
        }

        return $xmlary;
}

$ary = xml2array(file_get_contents('http://rcmsapi.chinacache.com:36000/customer/apple/channels'));

echo "<pre>";

print_r($ary);

echo "</pre>";

?>

 2:调用url

$url="http://www.baidu.com";  
echo file_get_contents($url);  

$fp=fopen($url,"r");  //第二种
    $response = '';  
            while($row = fgets($fp)) {  
                $response.= trim($row)."\n";  
            }
echo $response;

 3:调用url返回json数组的字符串,并转换为数组

 

<html>
<body>
<?php
$url='http://rcmsapi.chinacache.com:36000/customer/apple/channels';   
  
$dt_record=array();
$de_json = json_decode(file_get_contents($url),TRUE);
  
   $count_json = count($de_json);
        for ($i = 0; $i < $count_json; $i++)
           {
                  $dt_record[$i] = $de_json[$i]['code'];
                  
                };
?>
</body>
</html>

 4:通过url解析返回的xml

function get_bandwidth_by_qs($qs_url){
    $xml=simplexml_load_file($qs_url);
    foreach($xml->children() as $child)
  {
		if($child->getName()=='OutData')      //得到节点名
          return $child;                              //得到节点内容   
  }
}

 5:解决调用url返回结果有乱码问题

1、解决方法,找个ungzip的函数来转换下
2、给你的url加个前缀,这样调用
$content = file_get_contents("compress.zlib://".$url);
无论页面是否经过gzip压缩,上述代码都可以正常工作!


使用curl模块同样可解决问题
function curl_get($url, $gzip=false){
$curl = curl_init($url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($curl, CURLOPT_CONNECTTIMEOUT, 10);
if($gzip) curl_setopt($curl, CURLOPT_ENCODING, "gzip"); // 关键在这里
$content = curl_exec($curl);
curl_close($curl);
return $content;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值