企业对接Walmart平台API流程 On-request Reports 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 步:申请ITEM报告

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

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

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

指定所有必需参数的值:

reportType– 指定您要请求的报告(例如 reportType=ITEM)。
reportVersion– 指定报告版本(例如 reportVersion=v4)。
成功后,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", "Your 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");
}

public static String getAuthorization(String appKey, String appSecret) {
	Stringstr = appKey + ":" + appSecret;
	return "Basic " + Base64.encodeBase64String(str.getBytes());
}

2.2、构建公共请求方法

public static JSONObject 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请求";
	    JSONObject result= new JSONObject();
	    result.set("msg", msg);
        log.error(msg);
        return result;
    }

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

public static Map<String, String> getHeaders(Method method, String token) {
    Map<String, String> headers = new HashMap<>();
    headers.put("WM_SEC.ACCESS_TOKEN", token);
    headers.put("WM_QOS.CORRELATION_ID", IdUtil.randomUUID());
    headers.put("WM_SVC.NAME", "Your Shop name");
    headers.put("Accept", "application/json");
    if (Method.POST == method) {
        headers.put("Content-Type", "application/json");
    }
    return headers;
}

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);
     JSONObject response = request(Method.POST, url, param, JSONUtil.toJsonStr(jsonBody));
     log.info("response:{}", response);
 }

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

  • 10
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值