无法使用沃尔玛更新 Feed API
Unable to update feed using 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(正常)响应,但值未更新到沃尔玛提要中。
当我搜索沃尔玛 https://marketplace.walmartapis.com/v3/feeds?feedType=inventory
的端点 API 时,我发现了 2 个模式。
在这个回答中,我想提出一个使用以上 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
的表单发送。我认为这可能是您遇到问题的原因。
模式二:
在此模式中,使用了 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","quantity":{"unit":"EACH","amount":"20"}}]}'
这将转换为 Google Apps 脚本。
示例脚本:
var data = {"InventoryHeader":{"version":"1.4"},"Inventory":[{"sku":"JW00726","quantity":{"unit":"EACH","amount":25}},{"sku":"JW00663","quantity":{"unit":"EACH","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(),
"Accept": "application/json",
},
"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"
未在请求中使用 header.
- 在上面的脚本中,它假定您的
data
值和请求中的值 header 是使用 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(正常)响应,但值未更新到沃尔玛提要中。
当我搜索沃尔玛 https://marketplace.walmartapis.com/v3/feeds?feedType=inventory
的端点 API 时,我发现了 2 个模式。
在这个回答中,我想提出一个使用以上 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
的表单发送。我认为这可能是您遇到问题的原因。
模式二:
在此模式中,使用了 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","quantity":{"unit":"EACH","amount":"20"}}]}'
这将转换为 Google Apps 脚本。
示例脚本:
var data = {"InventoryHeader":{"version":"1.4"},"Inventory":[{"sku":"JW00726","quantity":{"unit":"EACH","amount":25}},{"sku":"JW00663","quantity":{"unit":"EACH","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(),
"Accept": "application/json",
},
"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"
未在请求中使用 header.- 在上面的脚本中,它假定您的
data
值和请求中的值 header 是使用 API 的正确值。请注意这一点。