news 2026/4/18 9:12:32

基于 OpenAPI 规范生成亚马逊广告(Amazon Ads)Java SDK

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
基于 OpenAPI 规范生成亚马逊广告(Amazon Ads)Java SDK

基于 OpenAPI 规范生成亚马逊广告(Amazon Ads)SDK 的工程化实践

注意:JDK最低要求11,本演示使用JDK17进行,可以在配置中指定JDK的位置。

一、背景:为什么需要自己生成 Amazon Ads SDK

在实际项目中接入Amazon Ads API时,通常会遇到几个现实问题:

  1. 接口数量极多
    • Sponsored Products
    • Sponsored Brands
    • Sponsored Display
    • Reports
    • Profiles / OAuth
  2. 官方 Java SDK 更新慢
  3. 手写接口:
    • 参数易错
    • DTO 维护成本高
    • Ads API 升级时改动巨大
  4. 多项目、多系统复用成本高

👉 本质问题只有一个:

接口是标准的,但我们一直在“重复造轮子”。


二、Amazon Ads 官方 OpenAPI 规范能力

Amazon Ads 官方已经提供了完整的 OpenAPI 规范文件

  • OpenAPI JSON 下载地址
    https://d1y2lf8k3vrkfu.cloudfront.net/openapi/en-us/dest/AmazonAdsAPIALLMerged_prod_3p.json
  • 官方 API 文档
    https://advertising.amazon.com/API/docs/en-us/amazon-ads/1-0/apis

这个 JSON 文件中已经完整描述了:

  • 所有 API Path
  • Request / Response Model
  • 参数校验规则
  • HTTP Method 与返回码

👉 这意味着:
Amazon Ads API 天然适合“代码生成”。


三、为什么选择 OpenAPI Generator

我们最终选择了openapi-generator,原因非常明确:

  • 支持 OpenAPI 3.x
  • 支持 Java / Spring 生态
  • 可生成完整 Maven 工程
  • 可作为 SDK 独立发布
  • 最主要的是官方也是使用这个工具去生成的但是生成的JS,并不是Java

相比手写接口,生成 SDK 可以解决:

问题生成 SDK 的价值
DTO 重复维护自动生成
参数错误编译期校验
接口升级重新生成即可
多项目复用Maven 依赖
团队协作统一协议

四、工程化目标设计

在实践中,我们给自己设定了几个明确目标:

  • ✅ 使用JDK 17
  • ✅ SDK 与业务系统解耦
  • ✅ 可独立打包为Jar
  • ✅ 通过Maven 依赖引入
  • ❌ 不把业务逻辑写进 SDK
  • ❌ 不在 SDK 中处理 OAuth

最终定位很清晰:

SDK = 协议层(HTTP + Model),不是业务层


五、生成 Amazon Ads Java SDK(实战)

cli可以去maven仓库下载,地址:https://mvnrepository.com/artifact/org.openapitools/openapi-generator-cli/7.18.0

准备:
1、下载好生成器openapi-generator-cli.jar
2、openapi规范文件,AmazonAdsAPIALLMerged_prod_3p.json
准备好以上的文件之后可以进行下面的步骤了。

1. 使用 openapi-generator-cli

注意:

# 设置 JDK 路径(根据实际情况调整)$JAVA_HOME="C:\Users\Administrator\.jabba\jdk\zulu@1.17.0-0"# 执行生成命令&"$JAVA_HOME\bin\java.exe"`-jar openapi-generator-cli.jar generate`-i AmazonAdsAPIALLMerged_prod_3p.json`-g java`-o amazon-ads-client`--library resttemplate`--group-id com.sifan.integration`--artifact-id amazon-ads-client`--artifact-version1.0.0`--api-package com.sifan.integration.amazonads.api`--model-package com.sifan.integration.amazonads.model`--invoker-package com.sifan.integration.amazonads.client`--additional-propertiesjava17=true,useJakartaEe=true,dateLibrary=java8,serializationLibrary=jackson,hideGenerationTimestamp=true ` --skip-validate-spec

这一步会直接生成一个完整的 Maven Java 工程


2. 生成结果结构

amazon-ads-client ├── pom.xml └── src/main/java └── com/sifan/integration/amazonads ├── api ├── model └── client

此时它已经具备了:

  • Api 接口类
  • Request / Response Model
  • HTTP Client 封装

下面是它生成后的代码结构,是一个完整的maven项目。

六、JDK 17 + Maven 打包成 SDK

由于项目目标是Java 17,需要确保 Maven 使用的 JDK 也是 17。

mvn cleaninstall-DskipTests

成功后即可得到:

amazon-ads-client-1.0.0.jar

并自动安装到本地 Maven 仓库。


七、在业务系统中使用 SDK

在主系统中,只需要像普通依赖一样引入:

<dependency><groupId>com.sifan.integration</groupId><artifactId>amazon-ads-client</artifactId><version>1.0.0</version></dependency>

然后在manager 层封装使用:

@ComponentpublicclassSponsoredProductsManager{privatefinalCampaignsApicampaignsApi;publicSponsoredProductsManager(ApiClientapiClient){this.campaignsApi=newCampaignsApi(apiClient);}}

👉 OAuth、Token 刷新、Header 注入全部放在业务系统中完成,SDK 保持“纯净”。


八、生成 SDK 带来的实际收益

1️⃣ 开发效率显著提升

  • 不再手写几十上百个接口
  • DTO 全自动生成
  • IDE 自动补全参数

2️⃣ 降低维护成本

  • Amazon Ads API 升级 → 重新生成 SDK
  • 不再人工 diff 接口变更

3️⃣ 工程结构更清晰

  • Ads SDK = 基础设施
  • 业务系统 = 业务逻辑
  • 职责边界明确

4️⃣ 避免重复造轮子

  • 一个 SDK
  • 多个系统复用
  • 多人协作无冲突

九、总结

Amazon Ads API 本身已经通过 OpenAPI 规范标准化,与其手写接口、维护 DTO,不如直接用规范驱动代码生成

通过 openapi-generator 生成 Amazon Ads SDK,并以 Maven 依赖的形式引入系统,是一种:

更工程化、更稳定、长期成本更低的解决方案。

这套方式不仅适用于 Amazon Ads,也同样适用于SP-API(官方有提供SDK)*、第三方平台 API、内部微服务 SDK

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 8:20:41

效率革命----Browser-Use 与 Cline:昨天,AI 终于学会了“自己操作电脑” [特殊字符]️

摘要:你是否想过,AI 不应该只在对话框里陪你聊天,而应该帮你去买票、填表、修 Bug?昨天 GitHub 上最火的两个 Agent 项目——Browser-Use(让 AI 控制浏览器)和 Cline(让 AI 控制 VS Code),正在把“全自动工作流”变成现实。本文手把手教你配置这两个神器,解放双手。 …

作者头像 李华
网站建设 2026/4/11 19:20:34

救命神器!专科生必用8款AI论文工具测评TOP8

救命神器&#xff01;专科生必用8款AI论文工具测评TOP8 为什么专科生需要这份AI论文工具测评&#xff1f; 随着人工智能技术的不断进步&#xff0c;越来越多的专科生开始借助AI工具提升论文写作效率。然而&#xff0c;面对市场上五花八门的AI论文辅助软件&#xff0c;如何选择真…

作者头像 李华
网站建设 2026/4/18 7:00:59

从入门到进阶:VitePress 构建高效静态站点全指

在静态站点生成器&#xff08;SSG&#xff09;领域&#xff0c;VitePress 凭借其极致的性能、Vue 生态的天然优势以及出色的开发者体验&#xff0c;迅速成为技术文档、个人博客和轻量营销站点的优选工具。作为 Vite 团队官方推出的静态站点方案&#xff0c;它不仅继承了 Vite 的…

作者头像 李华
网站建设 2026/4/18 3:52:50

【Java毕设全套源码+文档】基于ssm的高校学生社团管理系统设计与实现(丰富项目+远程调试+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/18 3:49:43

虾皮开店需要押金吗?要交多少押金

在虾皮&#xff08;Shopee&#xff09;开店&#xff0c;很多卖家关心的问题之一就是“要不要交押金&#xff1f;”。本文将依据虾皮官方最新规则&#xff0c;为你清晰、易懂地解答。 一、官方明确&#xff1a;开店无需押金 根据虾皮官方《卖家服务条款》和入驻政策&#xff…

作者头像 李华
网站建设 2026/4/18 3:48:06

ssm430摄影约拍系统的设计--论文

目录摘要开发技术源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;摘要 随着数字摄影技术的普及和社交媒体的发展&#xff0c;摄影约拍服务需求显著增长。传统约拍方式存在信息不对称、流程繁琐、效率低下等问题&#xff0c;难以满足摄影…

作者头像 李华