iOS内购IAP(十二) —— 一个详细的内购流程(一)

版本记录

版本号 时间
V1.0 2018.08.14

前言

大家都知道,ios虚拟商品如宝石、金币等都需要走内购,和苹果三七分成,如果这类商品不走内购那么上不去架或者上架以后被发现而被下架。最近有一个项目需要增加内购支付功能,所以最近又重新集成并整理了下,希望对大家有所帮助。感兴趣的可以参考上面几篇。
1. iOS内购IAP(一) —— 基础配置篇(一)
2. iOS内购IAP(二) —— 工程实践(一)
3. iOS内购IAP(三) —— 编程指南之关于内购(一)
4. iOS内购IAP(四) —— 编程指南之设计您的应用程序的产品(一)
5. iOS内购IAP(五) —— 编程指南之检索产品信息(一)
6. iOS内购IAP(六) —— 编程指南之请求支付(一)
7. iOS内购IAP(七) —— 编程指南之促进应用内购买(一)
8. iOS内购IAP(八) —— 编程指南之提供产品(一)
9. iOS内购IAP(九) —— 编程指南之处理订阅(一)
10. iOS内购IAP(十) —— 编程指南之恢复购买的产品(一)
11. iOS内购IAP(十一) —— 编程指南之准备App审核(一)

开始

构建iOS应用程序的一个好处是,您在应用程序货币化方面有很多选择:普通的vanilla付费应用程序,广告支持的免费应用程序,甚至支持应用程序内购买的应用程序。

应用内购买(或IAP)允许开发人员在使用应用时向用户收取特定功能或内容的费用。由于以下几个原因,实施IAP尤其引人注目:

  • 这是一种额外的赚钱方式,除了简单地预先付费购买应用程序。一些用户愿意在额外的内容或功能上花费更多。
  • 一个应用程序可以免费提供,这使其成为大多数人的简单下载。免费应用通常会比付费应用获得更多下载。如果用户喜欢该应用,那么他们可以在以后购买更多内容或功能。
  • 您可以在免费应用程序中向用户显示广告,并可选择通过购买IAP删除它们。
  • 在首次发布应用后,新的付费内容可以添加到同一个应用中,而不必开发全新的应用以赚取更多收益。

在此应用内购买教程中,您将利用IAP解锁应用中嵌入的额外内容。您需要熟悉基本的Swift和iOS编程概念。如果不熟悉这些,那么在开始之前您需要一个付费开发者帐户,可以访问iOS Developer CenterApp Store Connect

注意:本篇文章环境是Swift 4.2, iOS 12, Xcode 10。

在这个应用程序内购买教程中,您将构建一个名为“RazeFaces”的小应用程序,它允许用户购买“RazeFace”,是这个网站常用的书籍和视频的简洁插图。

A typical “RazeFace”

下载下来这个应用,然后在Xcode中打开。 Build并运行以查看它到目前为止的功能。 答案是:不是很多! 您将看到一个空表视图,导航栏中有一个Restore按钮,稍后将连接该按钮以恢复购买。

完成本教程后,将会在表格视图中列出一个您可以购买的RazeFaces列表。 如果您删除并重新安装该应用程序,Restore按钮将恢复以前购买的任何RazeFaces

前往Xcode快速查看代码。 主视图控制器位于MasterViewController.swift中。 此类显示tableview视图,其中包含可用IAP列表。 购买存储为SKProduct对象的数组。

请注意,MasterViewController正在使用一个名为IAPHelper类型的RazeFaceProducts.store的对象来完成繁重的工作。 看看他们各自的代码文件RazeFaceProducts.swiftIAPHelper.swift

RazeFaceProducts是一个简单的结构,包含有关应用程序中产品的一些信息,IAPHelper完成了与StoreKit交接的所有重要工作。 这些方法目前都已被删除,但您将在本教程中填写它们以向应用程序添加IAP功能。

在编写任何代码以合并IAP之前,您首先需要在iOS Developer CenterApp Store Connect中进行一些设置。


Creating an App ID - 创建一个App ID

首先,您需要创建一个App ID。 这会将您的应用与您的应用内购买产品相关联。 登录Apple Developer Center,然后选择Certificates, IDs & Profiles

接下来,选择Identifiers > App IDs,然后单击右上角的+以创建新的App ID

填写新App ID的信息。 输入Name为的RazeFace IAP Tutorial App。 选择Explicit App ID并输入唯一的Bundle ID。 通常的做法是反向使用您的域名(例如,com.razeware.razefaces)。 记下Bundle ID,因为在接下来的步骤中将需要它。

向下滚动到App Services部分。 请注意,默认情况下启用应用程序内购买和GameCenter。 单击Continue,然后单击RegisterDone

恭喜! 您有一个新的App ID! 接下来,您将在App Store Connect中创建匹配的应用程序。


Checking Your Agreements - 检查你的协议

在将iTunes添加到iTunes Connect中的应用程序之前,您必须执行以下两项操作:

  • 确保您已在developer.apple.com上接受最新的Apple Development Program License Agreement
  • 确保您已在App Store Connect.
    Agreements, Tax, and Billing部分中接受了最新的Paid Applications协议。

如果您还没有这样做,通常iTunes Connect会给您一个警告,如下所示:

如果您看到类似上述内容,请按照步骤接受相应的协议。

在iTunes Connect中仔细检查Agreements, Tax, and Banking部分也是很好的:

如果您看到标题为包含Paid Applications行的Request Contracts的部分,请单击Request按钮。 填写所有必要信息并提交。 您的申请可能需要一段时间才能获得批准。 只能等待!

否则,如果您看到Contracts In Effect中列出的Paid Applications,那么您似乎已经完成了此步骤! 不错的工作!

注意:提交后,Apple可能需要数天才能批准这些与IAP相关的协议。 在此期间,即使您在代码中正确实现了所有内容,也无法在应用中显示IAP产品。 对于首次实施应用内购买的人来说,这是令人沮丧的常见原因。只能等待!


Creating an App in iTunes Connect - 在iTunes Connect中创建一个App

现在要创建应用程序记录本身,单击页面左上角的App Store Connect,然后单击My Apps

接下来,单击页面左上角的+,然后选择New App以添加新的应用程序记录。 填写如下所示的信息:

您将无法使用您在此处看到的完全相同的应用程序Name,因为应用程序名称在App Store中必须是唯一的。 也许在上面屏幕截图中显示的示例标题之后添加您自己的首字母。

注意:如果您快速完成此步骤,则可能未在下拉列表中显示Bundle ID。 这有时需要一段时间才能通过Apple的系统认证。

单击Create,您就完成了!


Creating In-App Purchase Products - 创建IAP产品

提供IAP时,您必须首先在App Store Connect中为每个单独的购买添加条目。如果您曾在商店中列出待售的应用程序,那么这是一个类似的过程,包括选择购买的定价等级。当用户进行购买时,App Store处理向用户收费的复杂过程并回复有关此类操作的数据。

您可以添加一大堆不同类型的IAP:

  • Consumable - 消耗品:这些可以多次购买,可以用完。这些非常适合额外的生活,游戏内货币,临时能量等。
  • Non-Consumable - 非消耗品:您购买一次的东西,并期望具有永久性,如额外的水平和可解锁的内容。本教程中的RazeFace插图属于此类别。
  • Non-Renewing Subscription - 非续订订阅:在固定时间段内可用的内容。
  • Auto-Renewing Subscription - 自动续订订阅:重复订阅的内容,比如每一个月的期刊。

您只能为数字商品提供应用内购买,而不能为实体商品或服务提供应用内购买。有关所有这些的更多信息,请查看Apple关于Creating In-App Purchase Products的完整文档。

现在,在App Store Connect中查看应用程序的条目时,单击Features选项卡,然后选择In-App Purchases。要添加新的IAP产品,请单击In-App Purchases右侧的+。

你将会看到下面的弹窗

当用户在您的应用中购买RazeFace时,您会希望他们始终可以访问它,因此请选择Non-Consumable,然后单击Create

接下来,填写IAP的详细信息如下:

  • Reference Name - 参考名称:标识iTunes Connect中IAP的昵称。 此名称不会出现在应用中的任何位置。 您将通过此次购买解锁的RazeFace的标题是Swift Shopping,因此请在此处输入。
  • Product ID - 产品ID:这是标识IAP的唯一字符串。 通常最好从Bundle ID开始,然后附加一个特定于此可购买项目的唯一名称。 对于本教程,请确保添加swiftshopping,因为稍后将在应用程序中使用它来查找RazeFace以解锁。 例如,您可以使用:com.theNameYouPickedEarlier.razefaces.swiftshopping
  • Cleared for Sale - 清算待售:启用或禁用IAP的销售。
  • Price Tier - 价格层:IAP的价格成本。 选择Tier 1

现在向下滚动到Localizations部分,并注意英语(美国)有一个默认条目。 为Display NameDescription输入Swift Shopping。 单击Save。 很好! 您已经创建了第一个IAP产品。

注意:App Store Connect可能会报出您缺少IAP的元数据。 在您提交应用以供审核之前,您需要在此页面底部添加IAP的屏幕截图。 该屏幕截图仅用于Apple的审核review,不会出现在App Store列表中。

在深入研究一些代码之前还需要一个步骤。 在应用程序的开发版本中测试应用程序内购买时,Apple提供了一个测试环境,允许您“购买”您的IAP产品,而无需创建财务交易。

这些特殊测试购买只能通过App Store Connect中的特殊Sandbox Tester用户帐户进行。


Creating a Sandbox User - 创建沙盒账户

App Store Connect中,单击窗口左上角的App Store Connect以返回主菜单。 选择Users and Roles,然后单击Sandbox Testers选项卡。 单击Tester标题旁边的+。

填写信息,完成后单击Save。 您可以为测试用户编写名字和姓氏,但必须使用真实的电子邮件地址,因为Apple会向该地址发送验证电子邮件。 收到该电子邮件后,请务必点击其中的链接以验证您的邮箱地址。

您输入的电子邮件地址也不应与Apple ID帐户相关联。 提示:如果您有一个Gmail帐户,您只需使用address alias,而不必创建一个全新的帐户。

注意:不幸的是,测试新购买的non-consumable 的IAP需要每次都有一个新的沙箱测试者(和电子邮件地址)。 使用相同沙盒测试器的重复购买将被视为恢复已购买的项目,因此不会执行特定于新购买的任何代码。

如果需要通过新的购买代码进行多次测试并且您的电子邮件提供商不支持qualifiers,那么请考虑设置可消耗的IAP仅用于测试目的。 每次测试后删除设备上的应用程序,购买消耗的IAP将被视为新购买。

您可以采用的一种策略是在测试成功案例之前尽可能多次测试失败案例。 这样你就需要创建更少的沙盒测试器。 一般情况下,请记住,一旦用户(甚至是沙盒)购买了non-consumable的IAP,他就不能再次购买,只能恢复它。

太棒了 - 你现在有一个测试用户。 您最终可以在您的应用中实施IAP!

后记

本篇主要讲述了一个详细的内购流程,感兴趣的给个赞或者关注~~~

推荐阅读更多精彩内容