php中http_build_query 的一个问题
作者:bea
当我们使用CURL来post数据的时候,需要设置post的数据 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
当我们使用CURL来post数据的时候,需要设置post的数据
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 远程攻击者可以利用漏洞获得敏感内存信息。请大家谨慎使用
有用 | 无用
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乱码问题,UTF-8乱码常见问题小结
- PHP中return 和 exit 、break和contiue 区别与用法
- php 的加密函数 md5,crypt,base64_encode 等使用介绍
- PHP压缩html网页代码(清除空格,换行符,制表符,注释标记)
- PHP文件注释标记及规范小结
- 用PHP读取超大文件的实例代码
- PHP新手用的Insert和Update语句构造类
- PHP中SESSION使用中的一点经验总结
- PHP __autoload()方法真的影响性能吗?
- phpmyadmin3 安装配置图解教程
- php 注释规范
- php 计划任务 检测用户连接状态
- MySQL的FIND_IN_SET函数使用方法分享
- php提示无法加载或mcrypt没有找到 PHP 扩展 mbstring解决办法
- phpMyAdmin 链接表的附加功能尚未激活问题的解决方法(已测)
- phpMyAdmin出现无法载入 mcrypt 扩展,请检查PHP配置的解决方法
- simplehtmldom Doc api帮助文档
- php中一个有意思的日期逻辑处理