Ответ 1
Это скорее комментарий, чем ответ: из вашего вопроса не понятно, что конкретно вызывает ошибку 400, и что особенно означает это или более конкретное: источник этого.
Это вывод вашего сервера? Это какая-то обратная связь (завиток), которую вы выводите с помощью script?
Чтобы лучше отлаживать вещи, я придумал немного другую конфигурацию, которую вы могли бы заинтересовать при использовании расширения curl. Существует хорошая функция под названием curl_setopt_array
, которая позволяет вам установить сразу несколько параметров. Он вернет false, если один из вариантов завершится с ошибкой. Он позволяет настроить ваш запрос в полном объеме. Таким образом, вы можете легко вводить и заменять его с помощью второй (отладочной) конфигурации:
$curlDefault = array(
CURLOPT_PORT => 80, //ignore explicit setting of port 80
CURLOPT_RETURNTRANSFER => TRUE,
CURLOPT_FOLLOWLOCATION => TRUE,
CURLOPT_ENCODING => '',
CURLOPT_HTTPHEADER => array(
'Proxy-Connection: Close',
'User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/535.19 (KHTML, like Gecko) Chrome/18.0.1017.2 Safari/535.19',
'Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8',
'Accept-Encoding: gzip,deflate,sdch',
'Accept-Language: en-US,en;q=0.8',
'Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3',
'Cookie: __qca=blabla',
'Connection: Close',
),
CURLOPT_VERBOSE => TRUE, // TRUE to output verbose information. Writes output to STDERR, or the file specified using CURLOPT_STDERR.
);
$url = "http://stackoverflow.com/questions/tagged/java";
$handle = curl_init($url);
curl_setopt_array($handle, $curlDefault);
$html = curl_exec($handle);
curl_close($handle);
Это может помочь вам улучшить код и отладить вещи.
Кроме того, вы используете опцию CURLOPT_VERBOSE
. Это добавит подробную информацию в STDERR
, чтобы вы больше не могли ее отслеживать. Вместо этого вы можете добавить его к выходу, чтобы лучше понять, что происходит:
...
CURLOPT_VERBOSE => TRUE, // TRUE to output verbose information. Writes output to STDERR, or the file specified using CURLOPT_STDERR.
CURLOPT_STDERR => $verbose = fopen('php://temp', 'rw+'),
);
$url = "http://stackoverflow.com/questions/tagged/java";
$handle = curl_init($url);
curl_setopt_array($handle, $curlDefault);
$html = curl_exec($handle);
$urlEndpoint = curl_getinfo($handle, CURLINFO_EFFECTIVE_URL);
echo "Verbose information:\n<pre>", !rewind($verbose), htmlspecialchars(stream_get_contents($verbose)), "</pre>\n";
curl_close($handle);
Что дает следующий результат:
Verbose information:
* About to connect() to stackoverflow.com port 80 (#0)
* Trying 64.34.119.12...
* connected
* Connected to stackoverflow.com (64.34.119.12) port 80 (#0)
> GET /questions/tagged/java HTTP/1.1
Host: stackoverflow.com
Proxy-Connection: Close
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/535.19 (KHTML, like Gecko) Chrome/18.0.1017.2 Safari/535.19
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Encoding: gzip,deflate,sdch
Accept-Language: en-US,en;q=0.8
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3
Cookie: __qca=blabla
Connection: Close
< HTTP/1.1 200 OK
< Cache-Control: private
< Content-Type: text/html; charset=utf-8
< Content-Encoding: gzip
< Vary: Accept-Encoding
< Date: Mon, 05 Mar 2012 17:33:11 GMT
< Connection: close
< Content-Length: 10537
<
* Closing connection #0
Что должно предоставить вам информацию, необходимую для отслеживания вещей, если они связаны с запросом/завиванием. Затем вы можете легко изменить параметры и посмотреть, не изменилось ли это. Также сравните версию завитка, которую вы установили локально, с той, что была на сервере. Чтобы получить его, используйте curl_version
:
$curlVersion = curl_version();
echo $curlVersion['version']; // e.g. 7.24.0
Надеюсь, это поможет вам отследить все.