Błąd "Odwołanie do obiektu nie jest zainstalowany na wystąpienie obiektu" podczas próby aktualizacji produktu za pomocą API ShipStation

0

Pytanie

Mam problem z aktualizacją produktu na przystani.

Używam te 2 linki, aby zobaczyć, jak mi się należy sformatować odpowiedź:

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

Uważam, że dobrze wykonuję tego, ale ja zawsze dostaję komunikat o błędzie 500, w którym czytamy: "Odwołanie do obiektu nie jest zainstalowany na wystąpienie obiektu".

Użyłem żądanie GET, aby uzyskać atrybutów produktu. Następnie zaktualizować atrybuty, które chcesz zmienić, i zapisuję je w data (który jest tablicą obiektów). Następnie używam żądanie PUT dla wysyłania danych.

To odpowiedni kod:

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);
  }
}

Oto, co raw (dane, które wysyłam na stacji okrętowej) wyglądają tak: Wartości zerowe - to jest po prostu to, co dostaję z żądania GET. Wolałbym, aby te atrybuty pozostawały puste.

{"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}

Tak więc, czy ktoś ma jakieś wskazówki lub ktoś wcześniej używał API ShipStation i wykonywał zapytanie PUT? Co przeoczyłem?

1

Najlepsza odpowiedź

0

W swoim scenariuszu, jak o kolejnej modyfikacji?

Od:

var requestOptions = { 

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

  body: raw,
  redirect: 'follow'
};

Dla:

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

Link:

2021-11-24 00:30:32

Nie mogę uwierzyć, że to było tak po prostu naprawić. Dziękuję bardzo! przy okazji, masa użytkowa w swojej odpowiedzi jest napisane z błędem
oscark

@oscark Dziękuję, że odpowiedzieliście. Cieszę się, że twój problem został rozwiązany. Co do pisowni, dzięki, że sprawdziłeś ją. Chciałbym go zmienić. I tobie też dziękuję.
Tanaike

W innych językach

Ta strona jest w innych językach

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