我想用curl从URL中检索前10k个字节(在我的例子中使用PHP)。有没有办法指定这个?我认为CURLOPT_BUFFERSIZE会这样做,但它似乎只能确定在检索所有内容之前重用的缓冲区的大小。
答案 0 :(得分:6)
这就是我在c ++中的表现方式
int offset = 0;
int size = 10*1024;
char range[256];
curl_slist_s *pHeaders = NULL;
snprintf(range, 256, "Range: bytes=%d-%d", offset, offset+size-1);
pHeaders = curl_slist_append(pHeaders, range);
curl_easy_setopt(pCurlHandle, CURLOPT_HTTPHEADER, pHeaders);
curl_slist_free_all(pHeaders);
pHeaders = NULL;
编辑:刚刚发现你的意思是在php中。我会看看我是否能找到如何移植它。
认为这应该适用于php:
$offset = 0;
$size = 10*1024;
$a = $offset;
$b = $offset + $size-1;
curl_easy_setopt(curlHandle, CURLOPT_HTTPHEADER, array("Range: bytes=$a-$b") );
答案 1 :(得分:2)
这个怎么样:
// 1-10240 is range of downloaded bytes (10 kb = 10240 byte)
curl_setopt($ch, CURLOPT_RANGE,"1-10240");
答案 2 :(得分:1)
CURLOPT_RANGE似乎在PHP中不起作用,尽管它存在。至少当我尝试使用它时没有影响,谷歌搜索会发现许多同样的消息。
答案 3 :(得分:1)
如果您使用fread而不是curl,虽然我更喜欢curl,但您可以指定要接收的数据的大小,例如:
$fp = @fopen($url, "r") ;
$data = "" ;
if($fp) {
while (!feof($fp)) {
$data .= fread($fp, $size) ;
}
fclose($fp) ;
答案 4 :(得分:0)
$html='';
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL,$url);
curl_setopt($ch, CURLOPT_BUFFERSIZE, 128);
curl_setopt($ch, CURLOPT_NOPROGRESS, false);
curl_setopt($ch, CURLOPT_PROGRESSFUNCTION, function($DownloadSize, $Downloaded, $UploadSize, $Uploaded){ return ($Downloaded > 10240) ? 1 : 0;});
curl_setopt($ch, CURLOPT_WRITEFUNCTION, 'write_function');
curl_exec($ch);
curl_close($ch);
echo $html;
function write_function($handle, $data) {
global $html;
$html .= $data;
if (strlen($html) > 10240) {
return 0;
}
else
return strlen($data);
}