Etsy file upload (curl) Ошибка: тело запроса слишком велико - PullRequest
0 голосов
/ 14 ноября 2018

Мало практически одинаковых вопросов, но нет хорошего ответа.Я должен отправить изображения на конечную точку Etsy.

Решил использовать библиотеку lusitanian , найденную в git.Он внутренне использует curl для выполнения запроса POST.

Постоянно получает ответ «Слишком большое тело запроса».

Код:

$data = [
        //'@image' => new \CURLFile($imagePath, $mime, $imageFilename),
        '@image' => '@'.$imagePath.';type='.$mime,
    ];

    try {
        $response = $etsyService->request(
            $this->uri . '/' . $listingId . '/images',
            'POST',
            $data,
            array(
                'Content-Type'=>'multipart/form-data'
        );
        var_dump($response);die;
    } catch (\Exception $e) {
        var_dump($e->getMessage());
    }

Внутренне лузитанец использует это:

curl_setopt($ch, CURLOPT_POSTFIELDS, $requestBody);

чтобы сделать запрос.Пробовал оба сверху $ data.

Кто-нибудь знает, как это решить?

РЕДАКТИРОВАТЬ:

var_dump заголовка (curl_setopt ($ ch, CURLINFO_HEADER_OUT, true);)

    array (size=27)
      'url' => string 'https://openapi.etsy.com/v2/listings/645283994/images' (length=53)
      'content_type' => string 'text/plain;charset=UTF-8' (length=24)
      'http_code' => int 400
      'header_size' => int 895
      'request_size' => int 590
      'filetime' => int -1
      'ssl_verify_result' => int 0
      'redirect_count' => int 0
      'total_time' => float 0.234278
      'namelookup_time' => float 3.9E-5
      'connect_time' => float 0.023493
      'pretransfer_time' => float 0.083739
      'size_upload' => float 105
      'size_download' => float 29
      'speed_download' => float 123
      'speed_upload' => float 448
      'download_content_length' => float 29
      'upload_content_length' => float 105
      'starttransfer_time' => float 0.234254
      'redirect_time' => float 0
      'redirect_url' => string '' (length=0)
      'primary_ip' => string '151.101.13.224' (length=14)
      'certinfo' => 
        array (size=0)
          empty
      'primary_port' => int 443
      'local_ip' => string '192.168.2.73' (length=12)
      'local_port' => int 40466
      'request_header' => string 'POST /v2/listings/645283994/images HTTP/1.1

    Host: openapi.etsy.com

    User-Agent: PHPoAuthLib

    Accept: */*

    Authorization: OAuth oauth_consumer_key="**************************", oauth_nonce="****************************8", oauth_signature_method="HMAC-SHA1", oauth_timestamp="1542272124", oauth_version="1.0", oauth_token="*************", oauth_signature="******************"
Content-type: multipart/form-data
Connection: close
Content-Length: 105

1 Ответ

0 голосов
/ 19 ноября 2018

Проблема была (насколько я мог видеть) в лузитанской библиотеке.

В методе getSignature класса Signature строка 62 обозначает:

$signatureData[rawurlencode($key)] = rawurlencode($value);

По какой-то причине в этом $ signatureData также содержатся данные из тела запроса. Потому что здесь находится поле изображения, которое является объектом rowurlencode () и возвращает ноль!

Проблема решена (временно!) С помощью:

if(strpos($key, 'oauth_') !== false) {
    $signatureData[rawurlencode($key)] = rawurlencode($value);
}

И с тремя комментариями из класса curlClient 91 - 93.

Мне потребовалось несколько дней, чтобы выяснить это. Господин Президент, дайте мне медаль:)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...