PHP curl_exe c возвращает false, а curl_error возвращает пустую строку - PullRequest
0 голосов
/ 30 апреля 2020

При попытке выполнить запросы на получение и получить тело ответа curl_exe c возвращает false, а curl_error возвращает пустую строку.

Код выглядит следующим образом:

$curl = curl_init();

$opts = [
    CURLOPT_URL => '
    https://example.com'. $scope.'&item_value[]='.$param.'&api_key=XXXX',
    CURLOPT_RETURNTRANSFER => true, 
    CURLOPT_HEADER => false,
    CURLOPT_VERBOSE => true,
    CURLOPT_AUTOREFERER => true,
    CURLOPT_USERAGENT => 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.17 (KHTML, like Gecko) Chrome/24.0.1312.52 Safari/537.17'];

curl_setopt_array($curl, $opts);

var_dump($opts);

$response = curl_exec($curl);

var_dump($response);

if ($response === false) {
    $response = curl_error($curl);
    var_dump(curl_getinfo($curl));
}

var_dump($response);

curl_close($curl);

return($response);

Обратите внимание, что я попытался добавить CURLOPT_AUTOREFERER как попытку отладки запроса, то же самое для CURLOPT_USERAGENT, установленного на firefox. У меня был тот же результат без этих опций.

Также обратите внимание, что CURLOPT_URL, который я пытаюсь запросить, действителен на 100% (я var_dumped массив opts, чтобы убедиться, что вычисленный URL будет правильным, работает и возвращает данные, и это так).

Вывод выглядит следующим образом:

# var_dump $response

xxx.php:24:boolean false

# var_dump curl_error($curl) since $response == false

xxx.php:31:string '' (length=0)

# var_dump curl_getinfo($curl)

array (size=37)
  'url' => string '
        https://100%_valid_url.com' (length=180)
  'content_type' => null
  'http_code' => int 0
  'header_size' => int 0
  'request_size' => int 0
  'filetime' => int -1
  'ssl_verify_result' => int 0
  'redirect_count' => int 0
  'total_time' => float 0
  'namelookup_time' => float 0
  'connect_time' => float 0
  'pretransfer_time' => float 0
  'size_upload' => float 0
  'size_download' => float 0
  'speed_download' => float 0
  'speed_upload' => float 0
  'download_content_length' => float -1
  'upload_content_length' => float -1
  'starttransfer_time' => float 0
  'redirect_time' => float 0
  'redirect_url' => string '' (length=0)
  'primary_ip' => string '' (length=0)
  'certinfo' => 
    array (size=0)
      empty
  'primary_port' => int 0
  'local_ip' => string '' (length=0)
  'local_port' => int 0
  'http_version' => int 0
  'protocol' => int 0
  'ssl_verifyresult' => int 0
  'scheme' => string '' (length=0)
  'appconnect_time_us' => int 0
  'connect_time_us' => int 0
  'namelookup_time_us' => int 0
  'pretransfer_time_us' => int 0
  'redirect_time_us' => int 0
  'starttransfer_time_us' => int 0
  'total_time_us' => int 0

Очевидно, что с запросом что-то идет не так, но я не могу получить статус ошибки. Возможно, конфигурация сервера может запретить Curl?

1 Ответ

1 голос
/ 30 апреля 2020

Как из опубликованного кода, так и из "дампа var", похоже, что в URL есть новая строка, попробуйте

$opts = [
    CURLOPT_URL => 'https://example.com'.$scope.'&item_value[]='.$param.'&api_key=XXXX',
    // ...
...