当我们使用CURL来post数据的时候,需要设置post的数据 curl_setopt($c,CURLOPT_POSTFIELDS,$post_data); 假如这里的$data是 <div class="codetitle"><a style="CURSOR: pointer" data="24848" class="copybut" id="copybut24848" onclick="doCopy('code24848')"> 代码如下:<div class="codebody" id="code24848"> $data = array( 'name'=>'scofield', 'time'=>'2012-2-3' ) 接下来,需要先将$data变成字符串 $post_data = http_build_query($data); 而采用 http_build_query 转换后再 curl_setopt($c,$post_data); 看起来没有什么问题。但在实际操作中,$post_data 并没有被post过去。于是,自己写了个转换的方法后就OK了。 <div class="codetitle"><a style="CURSOR: pointer" data="16562" class="copybut" id="copybut16562" onclick="doCopy('code16562')"> 代码如下:<div class="codebody" id="code16562"> function getStr($array,$Separator='&') { if (empty($array)) return; if (!is_array($array)) { return $array; } $returnStr = ''; foreach ($array as $key => $val) { $temp = ''; if (is_array($val)) { for ($i = 0; $i < count($val); $i++) { $returnStr .= $key . '[' . $i . ']' . '=' . $val[$i] . $Separator; } } else { $returnStr.= $key . '=' . $val . $Separator; } } $returnStr = substr(trim($returnStr),-1); return $returnStr; } 感谢 黄斌-huangbin 童鞋的测试 http_build_query($data,"","&"); 即可,无需自己写方法解析了。http_build_query 远程攻击者可以利用漏洞获得敏感内存信息。请大家谨慎使用 (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|