问题一:超时设置
当将curl的超时时间误设置成很成的数值时(如1402919699,单位为秒),CURL应该将会过滤此值,而改将超时设置成0秒。最终导致一旦发生请求执行,就会引发超时错误Connection time-out。通过curl_getinfo($ch, CURLINFO_CONNECT_TIME
),可以看到对应连接消耗时间为0。
错误示例代码:
$ch = curl_init();//其他操作。。。//$maxTime 来自外部输入,超过一定阀值时会引发异常curl_setopt($ch, CURLOPT_TIMEOUT, $maxTime);curl_exec($ch);
解决方案:
应该对超时值进行控制判断。
$maxTime = ($maxTime > 0 && $maxTime < MAX_TIMEOUT) ? $maxTime : DFAULT_TIMEOUT;
问题二:CURLE_PARTIAL_FILE 错误 (18)
此类错误会提示:transfer closed with *** bytes remaining to read
主要在于设置了POST标志,却没有传递相应的参数,导致文件传输的尺寸不一致。
错误示例代码:
$ch = curl_init();//其他操作。。。//$data由外部传入,为空时会引发异常,如array()curl_setopt($ch, CURLOPT_POST, true);curl_setopt($ch, CURLOPT_POSTFIELDS, $data);curl_exec($ch);
解决方案:
if (!empty($data)) { curl_setopt($ch, CURLOPT_POST, true); curl_setopt($ch, CURLOPT_POSTFIELDS, $data);}
开发建议:
1、不要绝对相信和依赖第三方框架或者SDK
2、在使用扩展、第三方或者底层类库时,须明确每个调用会引发的问题,以及预防处理的方案
3、坚持单元测试,及早发现问题