如何高效学习苹果App Store Connect API用法

苹果官方文档一直被开发者诟病的点:

1、大部分是英文文档;

2、没有示例,不知道请求参数怎么传,返回哪些字段,格式是什么样;

3、文档太复杂,接口太多,不知道某个功能,该用哪个接口。

最近由于要处理大量内购商品(查询、检验、上传、修改),就再次研究了一下《App Store Connect API》,无意中有一个重大发现,直接让学习效率翻倍------那就是通过抓包App Store Connect苹果后台的网页请求来学习App Store Connect API接口使用

我对比发现,App Store Connect苹果后台的网页请求和App Store Connect API接口请求,只有域名和path上的差异,苹果后台的网页请求换下域名就变成了App Store Connect API请求,就可以直接用了

例如,请求某个App(假设App Apple ID为1436123456)的所有内购商品接口(官方文档

苹果后台网页的请求
appstoreconnect.apple.com/iris/v1/app...

AppStoreConnectAPI的请求
api.appstoreconnect.apple.com/v1/apps/143...

我们可以看到,网页请求的url,在域名appstoreconnect.apple.com前面加上api.变成二级域名api.appstoreconnect.apple.com,再拼上/iris/路径,就变成了AppStoreConnectAPI接口了。

苹果后台网页请求url
appstoreconnect.apple.com/iris/...

AppStoreConnectAPI请求url
api.appstoreconnect.apple.com/...

当你想实现某个功能,但不知道该用App Store Connect API哪个接口,或者你不知道请求参数怎么传,响应参数有哪些、数据结构是什么样,你就去抓包苹果后台网页请求,寻找疑似接口,再去对比《App Store Connect API》官方文档,文章开头的问题2和问题3直接解决了

这个技巧堪称神技,苹果的接口设计有些反人类,你不这么做,光看官方文档还真搞不定。

举个例子,修改内购商品的本地化商品名称。你得根据商品本地化状态(区别于内购商品的状态,每条本地化都有个单独的状态)的不同调不同的接口:

当你内购商品本地化态为,"准备提交"、"等待审核" 时,你需要调 Modify an In-App Purchase Localization这个接口。

当你内购商品本地化态为,"被拒绝" 时,你需要调 Create an In-App Purchase Localization

同样是修改名称,"被拒绝"状态时,却要调"Create"接口,没想到吧!苹果官方文档上没有任何这方面的描述,多亏了我这个"神技"看苹果怎么调用的,这个问题我估计要蒙圈好久。

授人以鱼不如授人以渔,以前我写过几篇关于App Store Connect API的具体用法,但时间久了可能会过时,也存在不全面等问题,自己也没有精力维护。所以,教会大家自力更生,才是上上策。

作者历史文章:
《App Store Connect API 》
如何自动化获取AppStore的销售和趋势报告

相关推荐
SmalBox1 天前
【节点】[Projection节点]原理解析与实际应用
unity3d·游戏开发·图形学
2601_958815161 天前
面向视疲劳缓解的手机贴膜光学系统设计:scinique®双护协同技术的工程实现
ios·智能手机·iphone·圆偏振光护眼·磁控溅射ar抗反射·iphone护眼膜
吠品2 天前
Go赋能:HTTP大文件秒传与断点续接
ios·iphone·xcode
唐诺2 天前
【无标题】
ios·属性包装器·wrappers
SmalBox2 天前
【节点】[Distance节点]原理解析与实际应用
unity3d·游戏开发·图形学
测试员周周2 天前
【Appium 系列】第14节-断言与验证 — Validator 的设计
android·人工智能·python·功能测试·ios·单元测试·appium
2501_916008892 天前
Mac 上生成 AppStoreInfo.plist 文件,App Store 上架
android·macos·ios·小程序·uni-app·iphone·webview
人月神话-Lee2 天前
【图像处理】高斯模糊——最优雅的模糊算法
图像处理·人工智能·算法·ios·ai编程·swift
@大迁世界2 天前
iPhone 18e,可能不再“低一档”
ios·iphone