Ошибка "Ссылка на объект не установлена на экземпляр объекта" при попытке обновить продукт с помощью API ShipStation

0

Вопрос

У меня возникли проблемы с обновлением продукта на судовой станции.

Я использую эти 2 ссылки, чтобы посмотреть, как мне следует отформатировать ответ:

https://www.shipstation.com/docs/api/products/update/ https://www.any-api.com/shipstation_com/shipstation_com/docs/Products/_products_productId_/PUT

Я считаю, что правильно следую этому, но я всегда получаю сообщение об ошибке 500, в котором говорится: "Ссылка на объект не установлена на экземпляр объекта".

Я использовал запрос GET для получения атрибутов продукта. Затем я обновляю атрибуты, которые необходимо изменить, и сохраняю их в data (который представляет собой массив объектов). Затем я использую запрос PUT для отправки данных.

Это соответствующий код:

function updateProducts(authString, data) {

  var baseProductUrl = `https://ssapi.shipstation.com/products/`;

  for(var d = 0; d < data.products.length; d++) { //for each product I'd like to update...

    var raw = data.products[d];
    raw = JSON.stringify(raw);

    var requestOptions = { 

      method: 'PUT',
      headers: {
        "Authorization": `Basic ${authString}`,
        "Content-Type": `application/json`,       
      },

      body: raw,
      redirect: 'follow'
    };

    var productUrl = `${baseProductUrl}${data.products[d].productId}`;
    UrlFetchApp.fetch(productUrl, requestOptions);
  }
}

Вот что raw (данные, которые я отправляю на судовую станцию) выглядят так: Нулевые значения - это просто то, что я получаю из запроса GET. Я бы предпочел, чтобы эти атрибуты оставались пустыми.

{"aliases":null,
"productId":123456789, //placeholder
"sku":"sku", //placeholder
"name":"UV Bulb - 1GPM - 10\"",
"price":19.99,
"defaultCost":null,
"length":2,
"width":2,
"height":13,
"weightOz":7,
"internalNotes":null,
"fulfillmentSku":null,
"active":true,
"productCategory":null,
"productType":null,
"warehouseLocation":null,
"defaultCarrierCode":null,
"defaultServiceCode":null,
"defaultPackageCode":null,
"defaultIntlCarrierCode":null,
"defaultIntlServiceCode":null,
"defaultIntlPackageCode":null,
"defaultConfirmation":null,
"defaultIntlConfirmation":null,
"customsDescription":"UV Bulb - 1GPM - 10\"", //attribute I'd like to update
"customsValue":9.99, //attribute I'd like to update
"customsTariffNo":null,
"customsCountryCode":"US",
"noCustoms":null,
"tags":null}

Итак, у кого-нибудь есть какие-либо подсказки или кто-нибудь раньше использовал API ShipStation и выполнял запрос PUT? Что я упускаю?

1

Лучший ответ

0

В вашем сценарии, как насчет следующей модификации?

От:

var requestOptions = { 

  method: 'PUT',
  headers: {
    "Authorization": `Basic ${authString}`,
    "Content-Type": `application/json`,       
  },

  body: raw,
  redirect: 'follow'
};

Для:

var requestOptions = { 
  method: 'PUT',
  headers: {
    "Authorization": `Basic ${authString}`,
  },
  payload: raw,
  contentType: "application/json",
};

Ссылка:

2021-11-24 00:30:32

Не могу поверить, что это было так просто исправить. Большое вам спасибо! кстати, полезная нагрузка в вашем ответе написана с ошибкой
oscark

@oscark Спасибо, что ответили. Я рад, что ваш вопрос был решен. Что касается орфографии, спасибо, что проверили ее. Я хотел бы изменить его. И тебе тоже спасибо.
Tanaike

На других языках

Эта страница на других языках

Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................