|
curl_setopt($c, CURLOPT_POSTFIELDS, $post_data);
假如這里的$data是
復制代碼 代碼如下:
$data = array(
'name'=>'scofield',
'time'=>'2012-2-3'
)
接下來,需要先將$data變成字符串
$post_data = http_build_query($data);
而采用 http_build_query 轉換后再
curl_setopt($c, CURLOPT_POSTFIELDS, $post_data);
看起來沒有什么問題。但在實際操作中,$post_data 并沒有被post過去。于是,自己寫了個轉換的方法后就OK了。
復制代碼 代碼如下:
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), 0, -1);
return $returnStr;
}
感謝 黃斌-huangbin 童鞋的測試 http_build_query($data,"","&"); 即可,無需自己寫方法解析了。
http_build_query 遠程攻擊者可以利用漏洞獲得敏感內存信息。請大家謹慎使用
php技術:php中http_build_query 的一個問題,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。