Я получаю это странное поведение при наборе веб-сайта с использованием сокета. Строка, возвращаемая из функции get_content() ниже, включает некоторую «дополнительную информацию», которая отсутствует на исходном веб-сайте.Странное поведение при использовании сокетов
function get_content($a, $b, $c = "00")
{
$request = "arg01=" . $a;
$request .= "&arg02=" . $b;
$request .= "&arg03=" . $c;
$host = "www.site.com";
$script = "/page.php";
$method = "POST";
$request_length = strlen($request);
$header = "$method $script HTTP/1.1\r\n";
$header .= "Host: $host\r\n";
$header .= "Content-Type: application/x-www-form-urlencoded\r\n";
$header .= "Content-Length: $request_length\r\n";
$header .= "Connection: close\r\n\r\n";
$header .= "$request\r\n";
$socket = @fsockopen($host, 80, $errno, $errstr);
if ($socket) {
fputs($socket, $header);
while(!feof($socket)) {
$output .= fgets($socket);
}
fclose($socket);
}
return $output;
}
Печать $ Выход:
HTTP/1.1 200 OK
Date: Fri, 24 Jul 2009 15:20:38 GMT
Server: Apache/2.2.8 (Unix) PHP/4.4.8
X-Powered-By: PHP/4.4.8
Connection: close
Transfer-Encoding: chunked
Content-Type: text/html
1f61
<html>
<head>
<title>
(...) html here (...)
<td align='right'><font size='-1'> 18,65</font></td>
(...) html here (...)
<td align='right'><font size='-1'> 24,10</font></td>
(...) html here (...)
<td align='right'><font size='-1'> 18,40</font></td>
(...) html here (...)
<td align='right'><font size='-1'> 24,10</font></td>
(...) html here (...)
<td align='right'><font size='-1'> 24,10</font></td>
(...) html here (...)
<td align='right'><font size='-1'> 18,65</font></td>
(...) html here (...)
<td align='right'><font size='-1'>
f43
24,10</font></td>
(...) html here (...)
<td align='right'><font size='-1'> 18,65</font></td>
(...) html here (...)
<td align='right'><font size='-1'> 18,65</font></td>
(...) html here (...)
<td align='right'><font size='-1'> 24,10</font></td>
(...) html here (...)
<td align='right'><font size='-1'> 18,40</font></td>
(...) html here (...)
</body>
</html>
0
Обратите внимание на блок ниже:
<td align='right'><font size='-1'>
f43
24,10</font></td>
Он не присутствует на оригинальном HTML. Должно быть
<td align='right'><font size='-1'> 24,10</font></td>
как у других тд-тегов.
Чтобы устранить эту проблему, я заменил гнезда на завиток.
function get_content($a, $b, $c = "00")
{
$args = "arg01=" . $a;
$args .= "&arg02=" . $b;
$args .= "&arg03=" . $c;
$host = "http://www.site.com/page.php";
$ch = curl_init($host);
curl_setopt($ch, CURLOPT_URL, $host);
curl_setopt($ch, CURLOPT_POST, count($args));
curl_setopt($ch, CURLOPT_POSTFIELDS, $args);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
curl_exec($ch);
$output = curl_multi_getcontent($ch);
curl_close($ch);
return $output;
}
Хотя CURL исправляет проблему, я хотел бы понять, что здесь происходит. Каково происхождение этой «дополнительной информации»? Из червоточины или что-то в этом роде?
У вас есть мысли?
Спасибо!
Чтобы усложнить его, наше недавнее обновление PHP (5.2.9, IIRC) ввело проблему, в которой fpassthru() больше не обрабатывает фрагментированные данные - он начал передавать длины в браузер. Мне пришлось отказаться от fpassthru() и отрешиться от ответа, прежде чем повторять каждый фрагмент. – grantwparks