仅适用于备选结算系统的应用内集成指南

本指南介绍了如何集成相关 API,以便在符合条件的应用中提供仅限备选结算系统(即无需用户自选)的结算方式。如需详细了解相关计划(包括资格要求和地理范围),请参阅备选结算系统简介

Play 结算库设置

向您的 Android 应用添加 Play 结算库依赖项。如需使用备选结算系统 API,您需要使用 6.1 或更高版本。

连接到 Google Play

集成流程的最初步骤与 Google Play 结算服务集成指南中所述的一些步骤相同,在初始化您的 BillingClient 时需进行一些调整:

以下示例演示了如何通过这些调整来初始化 BillingClient


var billingClient = BillingClient.newBuilder(context)
    .enableAlternativeBillingOnly()
    .build()
private BillingClient billingClient = BillingClient.newBuilder(context)
    .enableAlternativeBillingOnly()
    .build();

初始化 BillingClient 后,您需要按照集成指南中的说明与 Google Play 建立连接

检查可用性

您的应用应通过调用 isAlternativeBillingOnlyAvailableAsync 来确认可以使用仅限备选结算系统的结算方式。

如果可以使用仅限备选结算系统的结算方式,此 API 将返回 BillingResponseCode.OK。如需详细了解您的应用应如何响应其他响应代码,请参阅响应处理部分。


billingClient.isAlternativeBillingOnlyAvailableAsync(object:
    AlternativeBillingOnlyAvailabilityListener {
        override fun onAlternativeBillingOnlyAvailabilityResponse(
            billingResult: BillingResult) {
            if (billingResult.responseCode !=  BillingResponseCode.OK) {
                // Handle failures such as retrying due to network errors,
                // handling alternative billing only being unavailable, etc.
                return
            }

            // Alternative billing only is available. Continue with steps in
            // the guide.
        }
    });

billingClient.isAlternativeBillingOnlyAvailable(
    new AlternativeBillingOnlyAvailabilityListener() {
        @Override
        public void onAlternativeBillingOnlyAvailabilityResponse(
            BillingResult billingResult) {
            if (billingResult.getResponseCode() != BillingResponseCode.OK) {
                 // Handle failures such as retrying due to network errors,
                 // handling alternative billing only being unavailable,
                 // etc.
                return;
            }

            // Alternative billing only is available. Continue with steps in
            // the guide.
        }
    });

面向用户的信息对话框

如需集成仅限备选结算系统的结算方式,符合条件的应用必须显示一个信息界面,以帮助用户了解结算将不受 Google Play 的管理。每次启动备选结算流程之前,必须通过调用 showAlternativeBillingOnlyInformationDialog API 向用户显示此信息界面。如果用户已确认该对话框,此 API 通常不会再次显示该对话框。但在某些情况下(例如用户清除了设备上的缓存),系统可能会再次向用户显示该对话框。


// An activity reference from which the alternative billing only information
// dialog will be launched.
val activity : Activity = ...;

val listener : AlternativeBillingOnlyInformationDialogListener =
    AlternativeBillingOnlyInformationDialogListener { 
        override fun onAlternativeBillingOnlyInformationDialogResponse(
            billingResult: BillingResult) {
            // check billingResult
        }
}

val billingResult =
    billingClient.showAlternativeBillingOnlyInformationDialog(activity,
        listener)

// An activity reference from which the alternative billing only information
// dialog will be launched.
Activity activity = ...;

AlternativeBillingOnlyInformationDialogListener listener =
    new AlternativeBillingOnlyInformationDialogListener() {
        @Override
        public void onAlternativeBillingOnlyInformationDialogResponse(
            BillingResult billingResult) {
                // check billingResult
            }
    };

BillingResult billingResult =
    billingClient.showAlternativeBillingOnlyInformationDialog(activity,
        listener);

如果此方法返回 BillingResponseCode.OK,您的应用可以继续进行交易。如果返回 BillingResponseCode.USER_CANCELED,您的应用应调用 showAlternativeBillingOnlyInformationDialog 以再次向用户显示该对话框。如需了解其他响应代码,请参阅“响应处理”部分

向 Google Play 报告交易

通过备选结算系统进行的所有交易都必须在 24 小时内从后端调用 Google Play Developer API 并提供 externalTransactionToken(使用下文介绍的 API 获取),向 Google Play 报告相应交易。每笔一次性购买交易、每项新订阅以及对现有订阅的任何升级/降级都应生成新的 externalTransactionToken。如需了解在获取 externalTransactionToken 后如何报告交易,请参阅后端集成指南

billingClient.createAlternativeBillingOnlyReportingDetailsAsync(object:
    AlternativeBillingOnlyReportingDetailsListener {
        override fun onAlternativeBillingOnlyTokenResponse(
            billingResult: BillingResult,
            alternativeBillingOnlyReportingDetails:
                AlternativeBillingOnlyReportingDetails?) {
            if (billingResult.responseCode !=  BillingResponseCode.OK) {
                // Handle failures such as retrying due to network errors.
                return
            }

            val externalTransactionToken =
                alternativeBillingOnlyReportingDetails?
                    .externalTransactionToken

            // Send transaction token to backend and report to Google Play.
        }
    });

billingClient.createAlternativeBillingOnlyReportingDetailsAsync(
    new AlternativeBillingOnlyReportingDetailsListener() {
        @Override
        public void onAlternativeBillingOnlyTokenResponse(
            BillingResult billingResult,
            @Nullable AlternativeBillingOnlyReportingDetails
                alternativeBillingOnlyReportingDetails) {
            if (billingResult.getResponseCode() != BillingResponseCode.OK) {
                // Handle failures such as retrying due to network errors.
                return;
            }

            String transactionToken =
                alternativeBillingOnlyReportingDetails
                .getExternalTransactionToken();

            // Send transaction token to backend and report to Google Play.
        }
    });

响应处理

如果出现错误,上述方法 isAlternativeBillingOnlyAvailableAsync(), showAlternativeBillingOnlyInformationDialog()createAlternativeBillingOnlyReportingDetailsAsync() 可能会返回非 BillingResponseCode.OK 响应。建议按如下所述的方法处理错误:

  • ERROR:这是内部错误。请勿继续进行交易。 拨打电话重试 showAlternativeBillingOnlyInformationDialog(),用于显示信息 会再次显示该对话框 尝试进行购买。
  • FEATURE_NOT_SUPPORTED:当前设备上的 Play 商店不支持备选结算系统 API。请勿继续进行交易。
  • USER_CANCELED:不继续交易。致电 showAlternativeBillingOnlyInformationDialog() 以显示 系统就会在用户下一次尝试创建网站时向其 购买。
  • BILLING_UNAVAILABLE:交易无法使用仅限备选结算系统的结算方式,因此不应按照此计划继续进行。这是因为用户不在符合此计划条件的国家/地区,或者您的账号未成功注册此计划。如果是后一种情况,请在 Play 管理中心内检查您的注册状态。
  • DEVELOPER_ERROR:请求中存在错误。使用调试消息找出并更正错误,然后再继续交易。
  • NETWORK_ERROR, SERVICE_DISCONNECTED, SERVICE_UNAVAILABLE:这些是暂时性错误,应该重试。如果发生 SERVICE_DISCONNECTED 错误,请重新与 Google Play 建立连接,然后再重试。

测试备选结算系统

许可测试人员应该用于测试备选结算系统集成。您 对于许可测试人员发起的交易,系统不会开具账单 账号。如需了解详情,请参阅使用应用许可测试应用内购结算功能 了解如何配置许可测试人员

后续步骤

完成应用内集成后,您就可以集成后端了。