安装和配置 Android SDK
Adapty SDK 包含两个关键模块,可无缝集成到您的移动应用中:
- Core Adapty:这是 Adapty 正常运行所必需的核心 SDK。
- AdaptyUI:如果您使用 Adapty 付费墙编辑工具(一款无需编写代码即可轻松创建跨平台付费墙的工具),则需要此模块。AdaptyUI 会随核心模块一并自动激活。
想看看 Adapty SDK 如何集成到移动应用中的真实示例?查看我们的示例应用,其中展示了完整的配置流程,包括展示付费墙、发起购买以及其他基础功能。
系统要求
最低 SDK 要求:minSdkVersion 21
Adapty 兼容 Google Play Billing Library 8.x 及以下版本。默认情况下,Adapty 使用 Google Play Billing Library v.7.0.0,但如果您希望强制使用更新版本,可以手动添加依赖项。
安装 SDK 是 Adapty 配置流程的第 5 步。在您的应用内购买功能正常运行之前,您还需要将应用连接到应用商店,然后在 Adapty 控制台中创建产品、付费墙和版位。快速入门指南 将引导您完成所有必要步骤。
安装 Adapty SDK
选择您的依赖管理方式:
- 标准 Gradle:将依赖项添加到模块级
build.gradle - 如果项目使用
.gradle.kts文件,则将依赖项添加到模块级build.gradle.kts - 如果使用版本目录,则将依赖项添加到
libs.versions.toml文件,然后在build.gradle.kts中引用它
如果依赖无法解析,请确保你的 Gradle 脚本中包含 mavenCentral()。
添加方法说明
如果你的项目的 settings.gradle 中没有 dependencyResolutionManagement,请在顶层 build.gradle 的 repositories 末尾添加以下内容:
allprojects {
repositories {
...
mavenCentral()
}
}如果不是,请将以下内容添加到 settings.gradle 中 dependencyResolutionManagement 部分的 repositories 里:
dependencyResolutionManagement {
...
repositories {
...
mavenCentral()
}
}激活 Adapty SDK 的 Adapty 模块
基本设置
在应用代码中激活 Adapty SDK。
Adapty SDK 在应用中只需激活一次。
要获取您的 Public SDK Key:
- 前往 Adapty 控制台,导航至 App settings → General。
- 在 Api keys 部分,复制 Public SDK Key(不是 Secret Key)。
- 将代码中的
"YOUR_PUBLIC_SDK_KEY"替换为您的密钥。
- 请确保使用 Public SDK key 进行 Adapty 初始化,Secret key 仅应用于服务端 API。
- SDK keys 对每个应用都是唯一的,如果您有多个应用,请确保选择正确的密钥。
在调用任何其他 Adapty SDK 方法之前,请等待 Adapty.activate 完成。完整调用顺序请参阅 Android SDK 调用顺序。
接下来在应用中配置付费墙:
- 如果你使用 Adapty 付费墙编辑工具,请参阅付费墙编辑工具快速入门。
- 如果你自行构建付费墙 UI,请参阅自定义付费墙快速入门。
激活 Adapty SDK 的 AdaptyUI 模块
如果您计划使用付费墙编辑工具,则需要 AdaptyUI 模块。当您激活核心模块时,它会自动激活,无需执行任何其他操作。
配置 Proguard
在将应用发布到生产环境之前,请将 -keep class com.adapty.** { *; } 添加到您的 Proguard 配置中。
可选配置
日志记录
配置日志系统
Adapty 会记录错误及其他重要信息,帮助你了解运行状态。日志级别如下:
| 级别 | 描述 |
|---|---|
AdaptyLogLevel.NONE | 不记录任何日志。默认值 |
AdaptyLogLevel.ERROR | 仅记录错误日志 |
AdaptyLogLevel.WARN | 记录错误以及 SDK 中不会导致严重错误但值得关注的消息 |
AdaptyLogLevel.INFO | 记录错误、警告及各类信息消息 |
AdaptyLogLevel.VERBOSE | 记录调试时可能有用的所有附加信息,例如函数调用、API 请求等 |
| 您可以在配置 Adapty 之前,在应用中设置日志级别。 |
将日志系统消息重定向
如果你出于某些原因需要将 Adapty 的消息发送到自己的日志系统或保存到文件中,可以覆盖默认行为:
数据政策
Adapty 不会存储用户的个人数据,除非你明确发送,但你可以启用额外的数据安全策略,以符合应用商店或各国的法规要求。
禁用 IP 地址收集与共享
在激活 Adapty 模块时,将 ipAddressCollectionDisabled 设置为 true 即可禁用用户 IP 地址的收集与共享。默认值为 false。
使用此参数可以增强用户隐私保护、遵守地区数据保护法规(如 GDPR 或 CCPA),或在应用不需要基于 IP 的功能时减少不必要的数据收集。
禁用广告 ID(Ad ID)的收集与共享
激活 Adapty 模块时,将 adIdCollectionDisabled 设置为 true 可禁止收集用户的广告 ID。默认值为 false。
使用此参数可遵守 Play Store 政策,避免触发广告 ID 权限提示,或者在您的应用不需要基于广告 ID 的广告归因或分析时使用。
为 AdaptyUI 配置媒体缓存
默认情况下,AdaptyUI 会缓存媒体资源(如图片和视频),以提升性能并减少网络流量。你可以通过提供自定义配置来调整缓存设置。
使用 AdaptyUI.configureMediaCache 可以覆盖默认的缓存大小和有效期。此操作可选——如果不调用此方法,将使用默认值(磁盘大小 100MB,有效期 7 天)。
参数:
| 参数 | 是否必填 | 描述 |
|---|---|---|
| diskStorageSizeLimit | 可选 | 磁盘缓存总大小(字节)。默认为 100 MB。 |
| diskCacheValidityTime | 可选 | 缓存文件的有效期。默认为 7 天。 |
您可以在运行时使用 AdaptyUI.clearMediaCache(strategy) 清除媒体缓存,其中 strategy 可以是 CLEAR_ALL 或 CLEAR_EXPIRED_ONLY。
设置混淆账户 ID
Google Play 要求在特定场景下使用混淆账户 ID,以增强用户隐私和安全保护。这些 ID 帮助 Google Play 识别购买行为,同时保持用户信息的匿名性,在防欺诈和数据分析方面尤为重要。
如果你的应用涉及敏感用户数据,或需要符合特定隐私法规,就需要设置这些 ID。混淆 ID 让 Google Play 能够追踪购买记录,同时不暴露真实的用户标识符。
在自定义进程中运行 Adapty
默认情况下,Adapty 只能在应用的主进程中运行。 如果你的应用使用多个进程,请只初始化 Adapty 一次,否则可能出现意外行为。
如果需要在其他进程中运行 Adapty,请在配置中指定该进程:
如果你尝试在未设置此值的情况下在其他进程中激活 Adapty,SDK 将记录警告并跳过激活。
启用本地访问等级
默认情况下,本地访问等级在 Android 上是禁用的。要启用它,请将 withLocalAccessLevelAllowed 设置为 true:
故障排除
Android 备份规则(自动备份配置)
部分 SDK(包括 Adapty)会附带自己的 Android 自动备份配置。如果你同时使用了多个定义了备份规则的 SDK,Android 的 manifest 合并工具可能会报错,错误信息中通常会提到 android:fullBackupContent、android:dataExtractionRules 或 android:allowBackup。
常见报错示例:Manifest merger failed: Attribute application@dataExtractionRules value=(@xml/sample_data_extraction_rules) is also present at [com.other.sdk:library:1.0.0] value=(@xml/other_sdk_data_extraction_rules)
要解决此问题,您需要:
-
告知清单合并工具使用您应用的值来处理备份相关属性。
-
将 Adapty 和其他 SDK 的备份规则合并到单个 XML 文件中(Android 12+ 则需要一对文件)。
1. 在清单中添加 tools 命名空间
如果尚未添加,请在根标签 <manifest> 中加入 tools 命名空间:
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="com.example.app">
...
</manifest>
2. 在 <application> 中覆盖备份属性
在应用的 AndroidManifest.xml 中,更新 <application> 标签,使应用提供最终值并告知清单合并器替换库中的值:
<application
android:name=".App"
android:allowBackup="true"
android:fullBackupContent="@xml/sample_backup_rules"
android:dataExtractionRules="@xml/sample_data_extraction_rules"
tools:replace="android:fullBackupContent,android:dataExtractionRules">
...
</application>
如果其他 SDK 也设置了 android:allowBackup,请将其一并加入 tools:replace:
tools:replace="android:allowBackup,android:fullBackupContent,android:dataExtractionRules"
3. 创建合并备份规则文件
在 app/src/main/res/xml/ 目录下创建 XML 文件,将 Adapty 的规则与其他 SDK 的规则合并。由于 Android 根据操作系统版本使用不同的备份规则格式,同时创建这两个文件可确保应用支持的所有 Android 版本都能正常兼容。
以下示例以 AppsFlyer 作为第三方 SDK 示例。请根据实际使用的 SDK 替换或添加相应规则。
适用于 Android 12 及以上版本(使用新的数据提取规则格式):
<?xml version="1.0" encoding="utf-8"?>
<data-extraction-rules>
<cloud-backup>
<exclude domain="sharedpref" path="appsflyer-data"/>
<exclude domain="sharedpref" path="appsflyer-purchase-data"/>
<exclude domain="database" path="afpurchases.db"/>
<exclude domain="sharedpref" path="AdaptySDKPrefs.xml"/>
</cloud-backup>
<device-transfer>
<exclude domain="sharedpref" path="appsflyer-data"/>
<exclude domain="sharedpref" path="appsflyer-purchase-data"/>
<exclude domain="database" path="afpurchases.db"/>
<exclude domain="sharedpref" path="AdaptySDKPrefs.xml"/>
</device-transfer>
</data-extraction-rules>
适用于 Android 11 及更低版本(使用旧版完整备份内容格式):
<?xml version="1.0" encoding="utf-8"?>
<full-backup-content>
<exclude domain="sharedpref" path="appsflyer-data"/>
<exclude domain="sharedpref" path="AdaptySDKPrefs.xml"/>
</full-backup-content>
完成此配置后:
-
Adapty 的备份排除项(
AdaptySDKPrefs.xml)会被保留。 -
其他 SDK 的排除项(例如
appsflyer-data)也会生效。 -
清单合并器现在使用您应用的配置,不再因备份属性冲突而失败。
从其他应用返回后购买失败
如果启动购买流程的 Activity 使用了非默认的 launchMode,当用户从 Google Play、银行应用或浏览器返回时,Android 可能会错误地重新创建或复用该 Activity,导致购买结果丢失或被视为已取消。
为确保购买流程正常运行,请仅为启动购买流程的 Activity 使用 standard 或 singleTop 启动模式,避免使用其他模式。
在您的 AndroidManifest.xml 中,确保启动购买流程的 Activity 已设置为 standard 或 singleTop:
<activity
android:name=".MainActivity"
android:launchMode="standard" />