PHP 7.2 CURLFile выдает предупреждение «Неверное имя файла» - PullRequest
0 голосов
/ 14 февраля 2019

У меня проблема с использованием объекта CURLFile (curl_file_create).Я испробовал несколько подходов, но независимо от того, что я пытаюсь, я получаю предупреждение PHP в файлах журнала, и этот файл опускается в моем вызове cURL.

Во-первых, некоторая информация:

  • PHP 7.2
  • Файлы подтверждены, что они существуют и доступны для чтения PHP / Apache
  • php-curl и соответствующие библиотеки php обновлены
  • Это фрагмент изнутри объекта, то есть ссылки на $this.Все переменные загружаются правильно.
  • Это продолжение другого вопроса, который я начал, который, когда сужается, кажется, не связан с основной исходной темой (mailgun).На него можно ссылаться по этому URL, если хотите, но я намерен закрыть этот вопрос в ближайшее время. Вложения Mailgun с PHP cURL - Нет SDK
  • Примечание в блоке кода, где я закомментировал несколько других вариантов попытки добавить файл - все они создают одно и то же предупреждение / результат

Кодовый блок

$curl = curl_init();

$curlOpts = array(
    CURLOPT_POST => 1,
    CURLOPT_URL => $postUrl,
    CURLOPT_TIMEOUT => 20,
    CURLOPT_RETURNTRANSFER => 1,
    CURLOPT_HTTPAUTH => CURLAUTH_BASIC,
    CURLOPT_USERPWD => 'api:' . $this->apiKey
);

$postFields = array(
    'from' => $email->from,
    'to' => $email->to,
    'subject' => $email->subject
);

if (strlen($email->cc) > 0) {
    $postFields['cc'] = $email->cc;
}

if (strlen($email->bcc) > 0) {
    $postFields['bcc'] = $email->bcc;
}

if (strlen($email->html) > 0) {
    $postFields['html'] = $email->html;
} else {
    $postFields['text'] = $email->text;
}

if (count($email->attachments) > 0) {
    // Curl attachments for < PHP5.5 not supported
    if (function_exists('curl_file_create')) {
        $curlOpts[CURLOPT_SAFE_UPLOAD] = 1; // for < PHP 7
        //$curlOpts[CURLOPT_HTTPHEADER] = array('Content-Type: multipart/form-data');
        //$postFields['attachment'] = curl_file_create($email->attachments[0]);
        for ($i = 1; $i <= count($email->attachments); $i++) {
            $postFields['attachment[' . $i . ']'] = curl_file_create($email->attachments[$i - 1], 'text/csv', basename($email->attachments[$i - 1]));
            //$postFields['attachment[' . $i . ']'] = curl_file_create('/var/www/sites/domain/contact.csv', 'text/csv', 'contact.csv');
            //$postFields['attachment[' . $i . ']'] = curl_file_create('test.txt', 'text/plain', 'test.txt');
            //$postFields['attachment[' . $i . ']'] = curl_file_create(realpath('test.txt'), 'text/plain', 'test.txt');
            //$postFields['attachment[' . $i . ']'] = new \CURLFile($email->attachments[$i - 1]);
        }
    } else {
        \D3DevelForms\Models\Error::CreateAndSaveSystemError(
            $plugin, 
            \D3DevelForms\Common::ERROR_WARNING, 
            'PHP 5.5 or newer required for Mailgun Attachments', 
            \D3DevelForms\Models\Error::ERROR_CODE_API_MAILGUN_LOCAL_ERROR,
            'You are using an outdated version of PHP. Email attachments via Mailgun will be ignored.');
    }
}

$curlOpts[CURLOPT_POSTFIELDS] = $postFields;

$log->UpdateDebugLog('Mailgun API Options', $curlOpts);

curl_setopt_array($curl, $curlOpts);

$curl_response = curl_exec($curl);
$info = curl_getinfo($curl);

Параметры скручивания ($curlOpts)

Array
(
    [47] => 1
    [10002] => https://api.mailgun.net/v3/devtester.devtest.com/messages
    [13] => 20
    [19913] => 1
    [107] => 1
    [10005] => api:APIKEY
    [-1] => 1
    [10015] => Array
        (
            [from] => Dev Tester <devtester@devtest.com>
            [to] => devemail@gmail.com
            [subject] => Form Summary
            [text] => My Text Content
            [attachment[1]] => CURLFile Object
                (
                    [name] => /var/www/path_to/my_file.csv
                    [mime] => text/csv
                    [postname] => my_file.csv
                )

        )

)

Возвращенная информация скручивания ($info)

Array
(
    [url] => https://api.mailgun.net/v3/devtester.devtest.com/messages
    [content_type] => application/json
    [http_code] => 200
    [header_size] => 388
    [request_size] => 312
    [filetime] => -1
    [ssl_verify_result] => 0
    [redirect_count] => 0
    [total_time] => 0.503718
    [namelookup_time] => 0.004273
    [connect_time] => 0.0932
    [pretransfer_time] => 0.279756
    [size_upload] => 1021
    [size_download] => 105
    [speed_download] => 208
    [speed_upload] => 2026
    [download_content_length] => 105
    [upload_content_length] => 1021
    [starttransfer_time] => 0.368725
    [redirect_time] => 0
    [redirect_url] => 
    [primary_ip] => Y.Y.Y.Y
    [certinfo] => Array
        (
        )

    [primary_port] => 443
    [local_ip] => X.X.X.X
    [local_port] => 38636
)

Обновление: при тестировании cURL из командной строки, оно работает как задумано, в том числе когда я запускаю его как процесс apache.

sudo -u apache curl -s --user 'api:APIKEY' \
    https://api.mailgun.net/v3/devtester.devtest.com/messages \
    -F from='Dev Tester <devtest@devtester.devtest.com>' \
    -F to='devtester@gmail.com' \
    -F subject='Hello' \
    -F text='Testing some Mailgun awesomness!' \
    -F attachment=@/var/www/path_to/my_file.csv
{
    "id": "<AA.BB.CC@devtester.devtest.com>",
    "message": "Queued. Thank you."
}

Я получаю предупреждение PHP в журналах Apache, это выглядит следующим образом:

"Предупреждение PHP: curl_setopt_array (): неверное имя файла для вложения ключа [1]"

Это сложно, потому что я подтвердил следующее:

  • Файл существует
  • Файл доступен для чтения Apache
  • Путь к файлу не включает символы вне букв, цифр, слешей и дефисов
  • Посколькуфайл создается в той же теме, я пытался ссылаться на STAтик файл, но результат тот же.

1 Ответ

0 голосов
/ 14 февраля 2019

Eureka.Проблема в использовании curl_setopt_array.Я смог исправить проблему следующим образом:

//$curlOpts[CURLOPT_POSTFIELDS] = $postFields;

$log->UpdateDebugLog('Mailgun API Options', $curlOpts);

curl_setopt_array($curl, $curlOpts);
curl_setopt($curl, CURLOPT_POSTFIELDS, $postFields);

Я не сталкивался с какой-либо документацией по этому ограничению с помощью curl_setopt_array, поэтому я не уверен, что это было неправильное использование с моей стороны илиесли это неизвестная ошибка.

...