当前位置: 首页 > news >正文

基于 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

http://www.jsqmd.com/news/258990/

相关文章:

  • 如何安全批量更新数据库某个字段
  • 2025年精选:武汉地区加气块定制厂家推荐榜单,国内加气块定制厂家综合实力与口碑权威评选 - 品牌推荐师
  • Bandit游戏通关记录
  • 消费入口设计:1000元免单产品如何吸引海量流量?
  • 1.17记录
  • 导师推荐10个AI论文工具,专科生轻松搞定毕业论文!
  • 2026年金属保温装饰板材实力厂家权威推荐:金属雕花板/外墙保温装饰一体板/集成房屋墙板源头精选 - 品牌推荐官
  • 基于Vue的二手图书交易系统的设计与实现m7za7(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
  • 救命神器!专科生必用8款AI论文工具测评TOP8
  • 2026评测:进口保健食品中哪些供应商口碑佳?保健食品集合店/进口热销品集合店/进口保健食品,进口保健食品批发排行 - 品牌推荐师
  • 效率革命----Browser-Use 与 Cline:昨天,AI 终于学会了“自己操作电脑” [特殊字符]️
  • 2026年铝合金结构篷房厂家权威推荐榜单:玻璃墙铝合金篷房/轻强铝合金篷房/全透明铝合金篷房/新型铝合金篷房/快搭铝合金篷房源头厂家精选 - 品牌推荐官
  • ACPI!ACPIGetWorkerForInteger函数中的ACPI!ACPIGetConvertToDevicePresence设置BAT1不存在
  • L2-1 Compass评测书生大模型实践
  • GitHub Copilot 使用笔记
  • 微信立减金无损变现指南,0基础也能回收 - 淘淘收小程序
  • 2026年天津办理海葬公司权威推荐榜单:海葬办理/海葬祭奠代理 /海葬代理 /海葬祭奠办理/ 海葬祭奠 /骨灰海葬办理服务商精选 - 品牌推荐官
  • 如何以非管理员权限运行 regedit
  • 2026年管廊/隧道/风管/水管抗震支架实力推荐榜:江苏森基建筑工程科技有限公司,适配综合管廊/交通隧道/工业厂房多场景解决方案 - 品牌推荐官
  • 2026年室内篮球架厂家权威推荐榜单:落地式篮球架/壁挂式篮球架/户外篮球架/悬空式篮球架/移动篮球架源头厂家精选 - 品牌推荐官
  • 16G显卡也能调大模型?先搞懂显存消耗的3大核心原因
  • YOLOv5s/yolov7/yolov8+pyqt flask车流量检测(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 2026断桥铝门窗厂家权威推荐榜单:隔音系统门窗/铝合金门窗/门窗加盟/隔音音门窗/高端系统门窗源头厂家精选。 - 品牌推荐官
  • 2026苏果超市购物卡回收资质齐全的平台 - 淘淘收小程序
  • 基于YOLOV8的道路缺陷检测系统(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 【Java毕设源码分享】基于ssm+vue的怀旧小筑客栈管理系统的设计与实现(程序+文档+代码讲解+一条龙定制)
  • 基于YOLOv8+pyqt5的头盔检测系统(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • S25FL256S flash 驱动学习与 RDID 建立
  • 【Java毕设全套源码+文档】基于ssm的办公电脑配件商城设计与实现(丰富项目+远程调试+讲解+定制)
  • 2026年中银通支付卡回收最优选的三大平台 - 淘淘收小程序