无法使用 Walmart API 更新提要 修改后的脚本:示例脚本:

问题描述

var data = {
"file": "<InventoryFeed xmlns=\"http://walmart.com/\">\n    <InventoryHeader>\n        <version>1.4</version>\n    </InventoryHeader>\n    <inventory>\n        <sku>JW00726</sku>\n        <quantity>\n            <unit>EACH</unit>\n            <amount>25</amount>\n        </quantity>\n    </inventory>\n    <inventory>\n        <sku>JW00663</sku>\n        <quantity>\n            <unit>EACH</unit>\n            <amount>20</amount>\n        </quantity>\n    </inventory>\n</InventoryFeed>\n"
  };
  
  var options = {
    "method" : "POST","headers": {
        "Authorization": "Basic "+Global_Auth,"WM_QOS.CORRELATION_ID": Global_CORRELATION_ID,"WM_SVC.NAME": Global_SVC_NAME,"WM_SEC.ACCESS_TOKEN":GetAccesstoken(),"WM_CONSUMER.CHANNEL.TYPE": "#","Accept": "application/json","mimeType": "multipart/form-data","Content-Type": "application/x-www-form-urlencoded"
      },"payload" : data,"muteHttpExceptions" : true
  };
  var url = "https://marketplace.walmartapis.com/v3/Feeds?FeedType=inventory";
  var response = UrlFetchApp.fetch(url,options);
  var res = JSON.parse(response.getContentText());

在 API 响应中获得 200 (ok) 响应,但值未更新到 Walmart 提要中。

解决方法

当我搜索 Walmart API https://marketplace.walmartapis.com/v3/feeds?feedType=inventory 的端点时,我发现了 2 个模式。

  1. 好像这是官方文档。 Ref
  2. 这似乎是 Postman 的“Walmart Partner Apis Prod_Publish”。 Ref

在这个答案中,我想使用以上 2 个文档提出一个答案。

模式 1:

在这个模式中,使用了官方文档。在这种情况下,数据使用 multipart/form-data 发送。当你的脚本被修改时,它变成如下。数据来自您的脚本。

修改后的脚本:

var data = `<InventoryFeed xmlns="http://walmart.com/"><InventoryHeader><version>1.4</version></InventoryHeader><inventory><sku>JW00726</sku><quantity><unit>EACH</unit><amount>25</amount></quantity></inventory><inventory><sku>JW00663</sku><quantity><unit>EACH</unit><amount>20</amount></quantity></inventory></InventoryFeed>`;
var options = {
  "method": "POST","headers": {
    "Authorization": "Basic " + Global_Auth,"WM_QOS.CORRELATION_ID": Global_CORRELATION_ID,"WM_SVC.NAME": Global_SVC_NAME,"WM_SEC.ACCESS_TOKEN": GetAccessToken(),"WM_CONSUMER.CHANNEL.TYPE": "#","Accept": "application/json",},"payload": { "file": Utilities.newBlob(data,"text/xml") },// or "application/xml" instead of "text/xml"
  "muteHttpExceptions": true
};
var url = "https://marketplace.walmartapis.com/v3/feeds?feedType=inventory";
var response = UrlFetchApp.fetch(url,options);
var res = JSON.parse(response.getContentText());
  • 当使用 UrlFetchApp 请求 multipart/form-data 时,不需要设置内容类型。自动设置边界。
  • 当我看到您的脚本时,data 是作为表单发送的,内容类型为 application/x-www-form-urlencoded。我认为这可能是您出现问题的原因。

模式 2:

在此模式中,使用 Postman 的“Walmart Partner Apis Prod_Publish”。在这种情况下,数据使用 application/json 发送。示例卷曲如下。

curl --location --request POST 'https://marketplace.walmartapis.com/v3/feeds?feedType=inventory' \
--header 'WM_SVC.NAME: Walmart Marketplace' \
--header 'WM_QOS.CORRELATION_ID: test' \
--header 'Accept: application/json' \
--header 'WM_SEC.ACCESS_TOKEN: {{token}}' \
--header 'Content-Type: application/json' \
--data-raw '{"InventoryHeader":{"version":"1.4"},"Inventory":[{"sku":"1068155","quantity":{"unit":"EACH","amount":"10"}},{"sku":"10210321","amount":"20"}}]}'

这将转换为 Google Apps 脚本。

示例脚本:

var data = {"InventoryHeader":{"version":"1.4"},"Inventory":[{"sku":"JW00726","amount":25}},{"sku":"JW00663","amount":20}}]};
var options = {
  "method": "POST","headers": {
    "Wm-Qos.Correlation-Id": Global_CORRELATION_ID,"Wm-Svc.Name": Global_SVC_NAME,"Wm-Sec.Access-Token": GetAccessToken(),"contentType": "application/json","payload": JSON.stringify(data),"muteHttpExceptions": true
};
var url = "https://marketplace.walmartapis.com/v3/feeds?feedType=inventory";
var response = UrlFetchApp.fetch(url,options);
console.log(response.getContentText())
var res = JSON.parse(response.getContentText());

注意:

  • "mimeType": "multipart/form-data" 未在请求标头中使用。
  • 在上面的脚本中,它假设您的 data 值和请求标头中的值是使用 API 的正确值。请注意这一点。

参考:

,

我是来自 Walmart 支持团队的 Ezhilmaran。

我们迁移到新系统,不再支持现有系统。

此通讯已于 2020 年末发送。

请找到以下链接,以帮助您快速加入我们的新系统。

https://walmart.io/

https://walmart.io/onboarding

https://walmart.io/apiservices

https://walmart.io/apireference

谢谢,

埃兹尔马兰

沃尔玛 IO 支持团队。