本指南介绍如何建立 Unity 游戏与应用内购 (IAP) 商店进行交互所需的数字记录和关系。本指南针对的是 Unity IAP 购买 API。
应用内购 (IAP) 是通过资金交易购买数字商品的过程。一个平台的应用商店会允许购买代表数字商品的产品。这些商品有一个标识符(通常是字符串数据类型)。商品的类型 (Types) 可表示其耐用性:_订阅、消耗品_(可以多次购买)以及_非消耗品_(可以购买一次)是最常见的类型。
2.准备好游戏的商品标识符以便稍后在 Google Play Developer Console(开发者控制台)中使用。
data:image/s3,"s3://crabby-images/d9411/d94114f80619b213ed4812c320940b418a5f6a4b" alt=""
Build a signed non-Development Build Android APK from your game.
提示:务必妥善保存您的密钥库文件。始终需要原始密钥库来更新已发布的 Google Play 应用程序。
提示:在本地测试期间,请复用您上次上传的 APK 的 Bundle Version Code 以便允许侧载 (side-loading),无需先将已更改的 APK 上传到 Developer Console。请参阅 Android 平台 Player 设置。
通过用于发布游戏的 Google 帐户,将 Android 应用程序注册到 Google Play Developer Console。
注意:本指南使用 Google Play Alpha/Beta 测试方法来测试应用内购 (IAP) 集成情况。
注意:由于 Google 支付方式不允许您购买自己的商品,因此不应使用发布者的 Google 帐户来进行测试。所以,您需要创建一个非发布者的 Google 帐户来进行测试。
1.选择 Add new application。
data:image/s3,"s3://crabby-images/82719/827199dd7dc4f4d895380547b3edd8416a43feac" alt=""
2.为应用程序指定一个 Title(名称)。为了配置应用程序计费,立即选择 “Upload APK”。我们将在稍后步骤中准备和填写商店列表 (Store Listing)。
data:image/s3,"s3://crabby-images/3be45/3be45a3c65fda0951a4de04d556c46f88f449083" alt=""
3.导航至 ALPHA TESTING__,然后选择 Upload your first APK to Alpha__。选择并上传您的 APK。
data:image/s3,"s3://crabby-images/88491/88491950c02c44baf4a8f48ffd7ba5f096e2f8ff" alt=""
4.首先解决 Why can’t I publish? 弹窗中列出的任何问题,然后单击 Publish app 以发布您的 Alpha 应用程序。
**提示**:发布的 Alpha 应用程序最长可能要等待 24 小时才能从 Google Play 应用商店中供下载。同样,对应用程序的 IAP 进行的更改在发布后也可能最长需要等待 24 小时才可用(请参阅下文)。
**警告**:确保发布的应用程序是 Alpha 版本。如果发布生产 (Production) 版本,公众将能够访问未经过测试的应用程序。
data:image/s3,"s3://crabby-images/661b5/661b5d4c23fe5981c5231e75738bcfb03107fb9e" alt=""
在 Developer Console 中,为游戏添加一个或多个 IAP。
1.导航至 In-app Products__,然后选择 Add new product__。
data:image/s3,"s3://crabby-images/842ba/842bab1a5a459c9b4bdbcebd0b1dd4fe8e4f5b3b" alt=""
1.定义 Product ID__,然后选择 Continue__。
您可以在 __Managed product__ 中指定消耗品或非消耗品商品类型。Unity IAP 也支持 __Subscription__(订阅)商品类型。
注意:此处的 “Product ID” 是游戏源代码中使用的同一标识符,已通过 AddProduct()
或 AddProducts()
添加到 Unity IAP ConfigurationBuilder 实例。
1.填写 IAP 的 Title、Description 和 Default price。然后将 Inactive 按钮更改为 Active 以启用 IAP。
data:image/s3,"s3://crabby-images/bf610/bf6104ef86a3fc4b69172338171cc93a1662b2d2" alt=""
结果:
data:image/s3,"s3://crabby-images/3197c/3197c2c08d92f5677bf6f82447b95e0a2f64d700" alt=""
按照以下说明分配“测试用户”以授予其特殊许可证测试权限,允许他们为此应用程序免费购买任何 IAP,然后将这些用户注册为 Alpha 测试者 (Alpha Testers)。
注意:我们在此处使用了封闭式 Alpha 测试。也可以使用其他测试者分组方式。
1.通过 Developer Console 的 Settings > Account details > LICENSE TESTING 部分,为您要授予许可证来免费购买 IAP 的测试者添加 Google 帐户电子邮件地址。
注意:许可证测试设置可能会延迟 15 分钟才生效。
data:image/s3,"s3://crabby-images/ef1cd/ef1cd0db55d8f378607637236b02a2054cf105ab" alt=""
2.根据您的许可证测试用户列表,建立一个 Alpha 测试者 Google 帐户电子邮件地址列表。
data:image/s3,"s3://crabby-images/3e935/3e93502f60886653a99733c02d120e5059cfd5a7" alt=""
添加每个 Google 帐户电子邮件地址并为列表命名。
data:image/s3,"s3://crabby-images/2e1de/2e1def04830dbff436f20890d609ef53f34bb180" alt=""
3.与 Alpha 测试者共享 Opt-in URL(当可用时,一般是从发布 APK 开始经过多个小时的延迟之后),然后让测试者从商店安装该应用程序。
**注意**:为了测试更新,保留免费购买 IAP 的权限,测试者可以侧载 (side-load) 应用程序,更新应用商店下载的现有 APK 安装结果。
data:image/s3,"s3://crabby-images/23297/23297e47b4f5c1c2e8c2fae30ff79bed8679496e" alt=""
4.为了测试 IAP,请在使用 Alpha 测试者 Google 帐户登录的设备上进行购买。此过程会显示经过修改的购买对话框,其中指出本商品正在接受测试并且免费。
**警告**:如果不显示此对话框,则会向 Alpha 测试者 Google 帐户收取该商品的真实资金。
data:image/s3,"s3://crabby-images/a1407/a1407f8a640e535ea383c9dc24f97527e43a1e83" alt=""
Did you find this page useful? Please give it a rating:
Thanks for rating this page!
What kind of problem would you like to report?
Thanks for letting us know! This page has been marked for review based on your feedback.
If you have time, you can provide more information to help us fix the problem faster.
Provide more information
You've told us this page needs code samples. If you'd like to help us further, you could provide a code sample, or tell us about what kind of code sample you'd like to see:
You've told us there are code samples on this page which don't work. If you know how to fix it, or have something better we could use instead, please let us know:
You've told us there is information missing from this page. Please tell us more about what's missing:
You've told us there is incorrect information on this page. If you know what we should change to make it correct, please tell us:
You've told us this page has unclear or confusing information. Please tell us more about what you found unclear or confusing, or let us know how we could make it clearer:
You've told us there is a spelling or grammar error on this page. Please tell us what's wrong:
You've told us this page has a problem. Please tell us more about what's wrong:
Thank you for helping to make the Unity documentation better!
Your feedback has been submitted as a ticket for our documentation team to review.
We are not able to reply to every ticket submitted.