企业对接Walmart平台API流程 On-request Reports API(二)

对接On-request Reports API

    • 1、对接指南
      • 1.1 报告生成时间
      • 1.2 报告保留期
      • 1.3 请求限制
      • 1.4 报告请求工作流
      • 如何申请报告
        • 第 1 步:申请取消报告
        • 第 2 步:获取报表可用性状态
        • 第 3 步:下载报告 URL
    • 2、代码实现
      • 2.1、获取访问API的token
      • 2.2、构建公共请求方法
      • 2.3 编写demo测试创建报告API

1、对接指南

1.1 报告生成时间

请求报告后,需要 15 到 45 分钟才能生成,然后可供下载。

1.2 报告保留期

您请求的报告将保留 30 天。您可以使用报告的请求 ID 请求 30 天的报告,无需请求新的报告。

1.3 请求限制

您每小时可以为每种报告类型请求一份报告。虽然您可以同时请求多种报告类型,但每小时只能为每种报告类型发出一次请求。

1.4 报告请求工作流

  • 使用 创建报告请求 API 创建报告请求。对于每个请求,系统都会创建一个requestId,卖家可以使用该 ID 来跟踪所请求报告的状态。
  • 使用报告请求状态 API 检查报告请求提交状态,该 API 返回有关报告状态的所有详细信息。
    报表状态为READY后,您现在可以使用下载报表 URL API 下载报表。
  • (可选): 您还可以使用获取所有报告请求 API 获取所有报告请求的列表。
  • (可选):如果使用创建订阅 API设置通知:当您收到报告已准备就绪的通知时,可以使用下载报表 URL API 检索它以供下载。
    在这里插入图片描述

如何申请报告

第 1 步:申请取消报告

若要请求项目报告,请调用创建报告请求 API。

例如,调用v3/reports/reportRequests?reportType=REPORT-TYPE&reportVersion=v1

REPORT-TYPE替换为您需要请求的报告类型。

指定所有必需参数的值:

reportType– 指定您要请求的报告(例如 reportType=CANCELLATION)。
reportVersion– 指定报告版本(例如 reportVersion=v1)。
成功后,API 调用将返回一个 requestId ,您可以使用它来了解报告是否已准备好下载,以及请求的状态(例如 RECEIVEDINPROGRESS)。它还返回requestSubmissionDate, UTC 格式的值:YYYY-MM-DDTHH:mm:ssZ

您还可以设置通知,以便在报告状态为 READY 时触发。要设置通知,请参阅通知。

第 2 步:获取报表可用性状态

若要了解报告是否已准备好下载,请调用报告请求状态 API 以检索报告请求状态。当状态为READY时,您可以下载报告。API 只能检索过去 30 天内创建的请求的详细信息。

例如,使用requestId进行调用。v3/reports/reportRequests?{requestId}

成功后,此调用将检索指定requestId的状态(例如 SUBMITTEDINPROGRESSREADYERROR)。

第 3 步:下载报告 URL

若要下载请求的报告,请调用下载报告 URL API”,并指定“由报告状态通知发送”或从报告请求状态 API 调用发送的“链接”。requestID

例如,调用/v3/reports/downloadReport?requestId={requestId}

成功后,您将收到用于下载报告的 URL 以及 URL 过期时间:

	downloadURL– 用于下载报告的 URL。
	downloadURLExpirationTime– 下载 URL 过期时间。

为避免错误,请务必检查以下情况是否不适用于您的请求:

请求已过期。在这种情况下,报告不再可用。
如果报告尚不可用,请检查状态是否为INPROGRESS
可能是系统错误或数据错误。
如果 无效。请确保您拥有正确的 requestId,或者它在 30 天后仍未过期。

2、代码实现

2.1、获取访问API的token

public static String getAccessToken(String appKey, String appSecret) {
        String authorization = getAuthorization(appKey, appSecret);
        Map<String, String> headers = new HashMap<>();
        headers.put("Authorization", authorization);
        headers.put("WM_SVC.NAME", "Shop name");
        headers.put("WM_QOS.CORRELATION_ID", IdUtil.randomUUID());
        HttpResponse response = HttpRequest
                .post("https://marketplace.walmartapis.com/v3/token")
                .addHeaders(headers)
                .body("grant_type=client_credentials", "application/x-www-form-urlencoded")
                .execute();
        JSONObject jsonObject = JSONUtil.parseObj(response.body());
        return jsonObject.getStr("access_token");
    }

2.2、构建公共请求方法

public static String request(Method method,
                                 String url,
                                 Map<String, Object> paramMap,
                                 String jsonBody) {

        String appkey = "xxxxxx-xxxxxxxx8cb";
        String appSecret = "AOqxxxxxxxxxxxxxxxxxxxxxxbo";
        String accessToken = getAccessToken(appkey, appSecret);

        //appkey和appSecret换成自己的
        Map<String, String> headers = getHeaders(method, accessToken);
        // get请求拼接参数
        if (paramMap != null && paramMap.size() > 0) {
            if (url.indexOf("?") > 0) {
                url = url + "&" + HttpUtil.toParams(paramMap);
            } else {
                url = url + "?" + HttpUtil.toParams(paramMap);
            }
        }
        HttpResponse resp;

        if (method == Method.POST) {
            resp = HttpRequest.post(url)
                    .addHeaders(headers)
                    .body(jsonBody)
                    .execute();

        } else if (method == Method.GET) {
            resp = HttpRequest.get(url)
                    .addHeaders(headers)
                    .execute();
        } else {
            String msg = "仅支持GET 和POST请求";
            log.error(msg);
            return msg;
        }

        if (HttpStatus.HTTP_OK == resp.getStatus()) {
            log.info("接口响应数据response.body():{}", resp.body());
            return resp.body();
        } else {
            log.error("调用Walmart API 错误");
            return "调用Walmart API 错误";
        }
    }

2.3 编写demo测试创建报告API

 public static void main(String[] args) {


        String url = "https://marketplace.walmartapis.com/v3/reports/reportRequests";
        Map<String, Object> param = new HashMap<>();
        param.put("reportType", "ITEM");
        param.put("reportVersion", "v4");
        //1、把你想要展示到报告中的字段都可以往里面写
        //字段网址:https://developer.walmart.com/doc/us/mp/us-mp-onrequestreports/
        List<String> columns = Arrays.asList("SKU", "Item ID", "Product Name",
                "Price", "Lifecycle Status", "Publish Status", "Status Change Reason",
                "Average Rating", "Shelf Name");
        //2、添加过滤条件,这里以过滤 Publish Status = PUBLISHED为例子
        JSONObject statusFilter = new JSONObject();
        statusFilter.set("type", "enumFilter")
                .set("columnName", "Publish Status")
                .set("values", new String[]{"PUBLISHED"});
        //2.1、如果要过滤其他条件自行添加。比如过滤 10<=price<=1000
        JSONObject priceFilter = new JSONObject();
        priceFilter.set("type", "rangeFilter")
                .set("columnName", "Price")
                .set("from", "10")
                .set("to", "1000");
        //2.2、把上面所有filter放到filters集合
        JSONArray rowsFilters = new JSONArray();
        rowsFilters.add(statusFilter);
        rowsFilters.add(priceFilter);
        //3、构建body参数,把字段和过滤条件加进来
        JSONObject jsonBody = new JSONObject();
        jsonBody.set("excludeColumns", columns);
        jsonBody.set("rowFilters", rowsFilters);
        log.info("请求参数:{}" + jsonBody);
        String response = request(Method.POST, url, param, JSONUtil.toJsonStr(jsonBody));
        log.info("response:{}", response);
    }

创建报告API调用成功,返回requestId
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/433812.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Codeforces Round 932 (Div. 2) --- C. Messenger in MAC --- 题解

C Messenger in MAC 题目大意&#xff1a; 思路解析&#xff1a; 答案计算为 , 可以发现当所选的几个信息固定后&#xff0c;其实后面的一项就变为b_max - b_min&#xff0c;得到了这个结论之后&#xff0c;其实我们可以直接把整个信息按照b进行排序&#xff0c;枚举l,r&am…

Day36 网络概述、IP划分、网络模型

文章目录 网络发展史局域网和广域网局域网&#xff08;LAN&#xff09;广域网&#xff08;Wan&#xff09; 光猫路由器 IP地址基本概念地址划分特殊地址&#xff08;后续编程使用&#xff09;IP地址转换端口字节序 网络模型网络模型OSI模型&#xff08;了解&#xff09;TCP/IP模…

Python中的模块包第三方库详解

模块&包 模块 一个.py文件就是一个模块&#xff0c;里面是一些函数和变量&#xff0c;需要的时候可以导入。 模块命名规范: 1.以英文开头&#xff0c;不出现中文 2.模块名不应与系统内置函数重名 包 包本身就是一个文件夹&#xff0c;如果文件夹内有__init__.py文件&…

安防摄像头(IPC)的步进马达及IR-CUT驱动国产芯片——D6212

应用领域 安防摄像头&#xff08;IPC&#xff09;的步进马达及IR-CUT驱动。 02 功能介绍 D6212内置8路带有续流二极管的达林顿驱动管阵列和一个H桥驱动&#xff0c;单芯片即可实现2个步进电机和一个IR-CUT的直接驱动&#xff0c;使得电路应用非常简单。单个达林顿管在输入电…

跨域报错(预请求(OPTIONS)的问题)

查原因 是预请求(OPTIONS)的问题 解决方法&#xff08;后端改&#xff09; 指路博客.NET处理VUE OPTIONS请求问题_.net option请求-CSDN博客

Latte:一个类似Sora的开源视频生成项目

前段时间OpenAI发布的Sora引起了巨大的轰动&#xff0c;最长可达1分钟的高清连贯视频生成能力秒杀了一众视频生成玩家。因为Sora没有公开发布&#xff0c;网上对Sora的解读翻来覆去就那么多&#xff0c;我也不想像复读机一样再重复一遍了。 本文给大家介绍一个类似Sora的视频生…

C++的类与对象(三)

目录 类的6个默认成员函数 构造函数 语法 特性 析构函数 特性 类的6个默认成员函数 问题&#xff1a;一个什么成员都没的类叫做空类&#xff0c;空类中真的什么都没有吗&#xff1f; 基本概念&#xff1a;任何类在什么都不写时&#xff0c;编译器会自动生成以下六个默认…

别再为微信登录烦恼!Xinstall的Universal Links让你秒速直达APP!

微信登录Universal Links校验不通过&#xff1f;无法直达APP场景页面&#xff1f;别担心&#xff0c;Xinstall来帮你解决这一难题&#xff01; 随着移动互联网的迅猛发展&#xff0c;App已成为我们日常生活中不可或缺的一部分。而微信&#xff0c;作为拥有十亿用户的社交巨头…

STM32FreeRTOS信号量(STM32cube高效开发)

一、信号量 &#xff08;一&#xff09;信号量概括 信号量是操作系统中重要的一部分&#xff0c;信号量是一种解决同步问题的机制&#xff0c;可以实现对共享资源的有序访问。 FreeRTOS 提供了多种信号量&#xff0c;按信号量的功能可分为二值信号量、计数型信号量、互斥信…

FreeRTOS操作系统学习——FreeRTOS工程介绍

FreeRTOS工程介绍 核心文件 FreeRTOS的最核心文件只有2个&#xff1a; FreeRTOS/Source/tasks.cFreeRTOS/Source/list.c 文件功能如下图&#xff1a; 头文件相关 内存管理文件 文件在 Middlewares\Third_Party\FreeRTOS\Source\portable\MemMang 下&#xff0c;它也是放…

uniapp直接连接wifi(含有ios和安卓的注意事项)

前言 小程序中直接连接wifi-----微信小程序 代码 启动 //启动wifistartWifi() {return new Promise((resolve, reject) > {uni.startWifi({success: (res) > {console.log(启动wifi 成功, res)resolve(true)},fail: (err) > {console.error(启动wifi 失败, err)uni.s…

【教程】uni-app iOS打包解决profile文件与私钥证书不匹配问题

摘要 当在uni-app中进行iOS打包时&#xff0c;有时会遇到profile文件与私钥证书不匹配的问题。本文将介绍如何解决这一问题&#xff0c;以及相关的技术细节和操作步骤。 引言 在uni-app开发过程中&#xff0c;iOS打包是一个常见的操作。然而&#xff0c;有时会出现profile文…

SEMICON专题直播预告|一起聊聊半导体测试

2024年3月20日&#xff0c;全球最大规模半导体嘉年华——SEMICON China 2024将在上海新国际博览中心盛大启幕&#xff0c;作为半导体测试领域的领军企业&#xff0c;加速科技即将重装亮相此次盛会&#xff08;N2馆N2327&#xff09;。 在正式开展之前&#xff0c;加速科技将举…

2024年最受欢迎的15款缺陷管理工具

本文整理分享了15款再2024年受欢迎的bug&#xff08;缺陷&#xff09;跟踪管理工具&#xff1a;1.PingCode&#xff1b;2.Worktile&#xff1b;3.SpiraTeam&#xff1b;4. Jira Software&#xff1b;5. BugHerd&#xff1b;6. Zoho Projects&#xff1b;7.SmartSheet&#xff1…

腾讯云服务器5年优惠活动价格表(2核4G和4核8G)

腾讯云服务器网整理五年云服务器优惠活动 txyfwq.com/go/txy 配置可选2核4G和4核8G&#xff0c;公网带宽可选1M、3M或5M&#xff0c;系统盘为50G高性能云硬盘&#xff0c;标准型S5实例CPU采用主频2.5GHz的Intel Xeon Cascade Lake或者Intel Xeon Cooper Lake处理器&#xff0c;…

5G网络深度覆盖提升感知优化案例

随着5G业务的发展&#xff0c;用户感知尤为重要&#xff0c;随着人们的生活水平不断提高&#xff0c;对网络使用的要求也越来越高&#xff0c;用户感知更加重要&#xff0c;数据业务已超越语音业务成为流量和收入的主体&#xff0c;信号质量的决定作用更明显。5G TDD的频谱大带…

【CSP试题回顾】202203-2-出行计划

CSP-202203-2-出行计划 关键点&#xff1a;前缀和数组&#xff08;高频考点&#xff09; 详见&#xff1a;【CSP考点回顾】前缀和数组 解题思路 解法利用差分数组技巧&#xff0c;使得更新时间区间的操作和查询操作的时间复杂度都是 O(1)&#xff0c;整体算法的时间复杂度主…

2024年最全洗地机选购攻略盘点丨希亦、小米、云鲸、海尔洗地机哪款值得入手?

在现代家居清洁中&#xff0c;洗地机是不可或缺的得力助手&#xff0c;它融合了吸尘、拖地等多种功能。面对市场上琳琅满目的洗地机品牌和型号&#xff0c;选择一个可靠的品牌至关重要。优质的品牌能够提供高品质的产品&#xff0c;使您的清洁工作更加轻松高效。本文将向您推荐…

基于多时间尺度的植被干旱响应特征与机制分析

随着全球气候变暖的趋势愈发明显&#xff0c;干旱事件不仅发生的频率增加&#xff0c;其持续时间和影响范围也在不断扩大。干旱对生态环境造成了严重破坏&#xff0c;导致生物多样性减少、土地退化和水资源短缺&#xff1b;对农业生产而言&#xff0c;干旱会导致作物减产甚至绝…

回溯算法04-组合总数(Java)

4.组合总数 题目描述 给你一个 无重复元素 的整数数组 candidates 和一个目标整数 target &#xff0c;找出 candidates 中可以使数字和为目标数 target 的 所有 不同组合 &#xff0c;并以列表形式返回。你可以按 任意顺序 返回这些组合。 candidates 中的 同一个 数字可以…