将 Chartboost 与中介集成

本指南介绍了如何使用 Google 移动广告 SDK 使用中介加载和展示来自 Chartboost 的广告,其中涵盖了广告瀑布流集成。其中介绍了如何将 Chartboost 添加到广告单元的中介配置,以及如何将 Chartboost SDK 和适配器集成到 iOS 应用中。

支持的集成和广告格式

Chartboost 的中介适配器具有以下功能:

集成
出价
瀑布
表现形式
横幅
插页式广告
激励广告
原生

要求

  • iOS 部署目标为 12.0 或更高版本
  • 最新版 Google 移动广告 SDK

  • 完成中介入门指南

第 1 步:在 Chartboost 界面中设置配置

注册 Chartboost 账号,并在账号通过验证后登录。然后,前往应用管理标签页。

Chartboost 应用信息中心

点击添加新应用按钮以创建应用。

应用管理

填写表单的其余部分,然后点击添加应用按钮以最终确定应用。

新应用表单

创建应用后,您将进入其信息中心。记下应用的应用 ID应用签名

应用设置

Ad Manager 要求您提供 Chartboost 用户 ID用户签名,才能设置 Ad Manager 广告单元 ID。您可以在 Chartboost 界面中点击 Chartboost 中介,找到这些参数。

Chartboost Mediation 信息中心

前往 Resources > API Explorer 标签页,记下 Authentication 部分下的 User IDUser Signature

Chartboost API Explorer

开启测试模式

如需为应用启用测试模式,请前往 Chartboost 界面的应用管理标签页,从列表中选择您的应用,然后点击修改应用设置

修改应用设置

您可以在应用的设置中为应用切换测试模式

Chartboost 测试模式

启用测试模式后,您可以使用之前创建的广告单元 ID 请求广告,并接收 Chartboost 测试广告。

在您能够接收 Chartboost 测试广告后,您的应用将被列入 Chartboost 的发布商应用审核名单。若要在 Chartboost 上创收,发布商应用审核需要获得 Chartboost 的批准。

第 2 步:在 Ad Manager 界面中设置 Chartboost 需求来源

为广告单元配置中介设置

登录您的 Ad Manager 账号

依次前往投放 > 收益组,然后点击新建收益组按钮。

为收益组输入唯一的名称,将状态设为有效,选择广告格式,并将广告资源类型设为移动应用。在定位 > 广告资源部分下,选择您要添加中介的广告资源移动应用下的广告单元。

接下来,点击添加收益合作伙伴按钮。

如果您已经有 Chartboost 的收益合作伙伴,可以选择该合作伙伴。否则,请选择创建新的收益合作伙伴

选择 Chartboost 作为广告联盟,输入唯一的名称,然后启用中介

开启自动收集数据,然后输入您在上一部分中获取的用户 ID用户签名

选择收益合作伙伴后,选择移动 SDK 中介作为集成类型,选择 iOS 作为平台,并选择有效作为状态。输入您在上一部分中获取的应用 ID应用签名广告位置。然后,输入默认每千次展示定价值。

Chartboost 广告展示位置(命名展示位置)是指表示您要在应用中展示广告的位置的简单名称。Ad Manager 会向设置中指定的位置发送请求。发送请求后,Chartboost 会将相应位置添加到其界面中,以便生成报告。

在 Chartboost 界面中,点击高级设置,即可在基本设置页面中显示您的广告展示位置。如需了解详情,请参阅 Chartboost 命名地理位置指南。

完成后,点击页面底部的保存

将 Chartboost 添加到 GDPR 和美国州级法规广告合作伙伴名单

请按照欧洲法规设置美国州级法规设置中的步骤,将 Chartboost 添加到 Ad Manager 界面中的欧洲法规和美国州级法规广告合作伙伴名单中。

第 3 步:导入 Chartboost SDK 和适配器

  • 将以下行添加到项目的 Podfile 中:

    pod 'GoogleMobileAdsMediationChartboost'
    
  • 在命令行中运行以下命令:

    pod install --repo-update

手动集成

  • 下载最新版本的 Chartboost SDK,并在项目中关联 Chartboost.frameworkCHAMoatMobileAppKit.framework

  • 更新日志中的下载链接下载最新版本的 Chartboost 适配器,并在项目中关联 ChartboostAdapter.framework

  • 将以下框架添加到您的项目中:

    • StoreKit
    • Foundation
    • CoreGraphics
    • WebKit
    • AVFoundation
    • UIKit

第 4 步:在 Chartboost SDK 中实现隐私设置

根据 Google 《欧盟地区用户意见征求政策》,您必须确保向位于欧洲经济区 (EEA) 的用户披露相关信息并征得他们的同意,以便使用设备标识符和个人数据。此政策反映了欧盟《电子隐私指令》和《一般数据保护条例》(GDPR) 的要求。在征求用户意见时,您必须指明中介链中可能会收集、接收或使用个人数据的每个广告联盟,并提供有关每个广告联盟使用情况的信息。Google 目前无法自动将用户的意见征求选择传递给此类广告联盟。

在 SDK 版本 8.2.0 中,Chartboost 添加了 addDataUseConsent 方法。以下示例代码将数据使用意见征求设置为 CHBGDPRConsentNonBehavioral。如果您选择调用此方法,建议您先调用此方法,然后再通过 Google 移动广告 SDK 请求广告。

Swift

let dataUseConsent = CHBDataUseConsent.GDPR(CHBDataUseConsent.GDPR.Consent.nonBehavioral)
Chartboost.addDataUseConsent(dataUseConsent)

Objective-C

CHBGDPRDataUseConsent *dataUseConsent = [CHBGDPRDataUseConsent gdprConsent:CHBGDPRConsentNonBehavioral];
[Chartboost addDataUseConsent:dataUseConsent];

如需了解详情以及每种方法中可以提供的值,请参阅 Chartboost 的 GDPR 文章iOS 隐私权方法

美国州级隐私保护法律

美国各州隐私权法要求,您必须向用户提供选择拒绝出售其个人信息的权利(该法律对这些术语进行了定义)。“出售”方须在首页醒目位置提供“不出售我的个人信息”链接,以供用户选择。美国州级隐私保护法律合规指南提供了为 Google 广告投放启用受限的数据处理的功能,但 Google 无法将此设置应用于中介链中的每个广告网络。因此,您必须找出中介链中可能参与销售个人信息的每个广告联盟,并遵循每个广告联盟的指南,以确保合规。

在 SDK 版本 8.2.0 中,Chartboost 添加了 addDataUseConsent 方法。以下示例代码将数据使用意见征求设置为 CHBCCPAConsentOptInSale。如果您选择调用此方法,建议您先调用此方法,然后再通过 Google 移动广告 SDK 请求广告。

Swift

let dataUseConsent = CHBDataUseConsent.CCPA(CHBDataUseConsent.CCPA.Consent.optInSale)
Chartboost.addDataUseConsent(dataUseConsent)

Objective-C

CHBCCPADataUseConsent *dataUseConsent = [CHBCCPADataUseConsent ccpaConsent:CHBCCPAConsentOptInSale];
[Chartboost addDataUseConsent:dataUseConsent];

如需了解详情以及每种方法中可以提供的值,请参阅 Chartboost 的 CCPA 文章iOS 隐私权方法

错误代码

如果适配器未能从 Chartboost 收到广告,您可以使用以下类下的 GADResponseInfo.adNetworkInfoArray 检查广告响应中的底层错误:

GADMAdapterChartboost
GADMediationAdapterChartboost

以下是 Chartboost 适配器在广告加载失败时抛出的代码和随附消息:

错误代码 原因
101 在 Ad Manager 界面中配置的 Chartboost 服务器参数缺失/无效。
102 Chartboost SDK 返回了初始化错误。
103 Chartboost 广告不会在展示时缓存。
104 请求的广告尺寸与 Chartboost 支持的横幅广告尺寸不符。
105 设备的操作系统版本低于 Chartboost SDK 支持的最低操作系统版本。
200-299 Chartboost SDK 缓存错误。如需了解详情,请参阅代码
300-399 Chartboost SDK 显示错误。如需了解详情,请参阅代码
400-499 Chartboost SDK 点击错误。如需了解详情,请参阅代码

Chartboost iOS 中介适配器变更日志

版本 9.8.0.0

  • 已验证与 Chartboost SDK 版本 9.8.0 的兼容性。

构建和测试所需版本:

  • Google 移动广告 SDK 11.11.0 版。
  • Chartboost SDK 版本 9.8.0。

版本 9.7.0.1

  • 更新了 CFBundleShortVersionString,使其包含三个组件,而不是四个。

构建和测试所需版本:

  • Google 移动广告 SDK 版本 11.10.0。
  • Chartboost SDK 版本 9.7.0。

版本 9.7.0.0

  • 已验证与 Chartboost SDK 版本 9.7.0 的兼容性。

构建和测试所需版本:

  • Google 移动广告 SDK 11.2.0 版。
  • Chartboost SDK 版本 9.7.0。

版本 9.6.0.1

  • 现在,最低 iOS 版本要求为 12.0。
  • 现在需要 Google 移动广告 SDK 11.0 或更高版本。
  • ChartboostAdapter.xcframework 中的框架中添加了 Info.plist

构建和测试所需版本:

  • Google 移动广告 SDK 版本 11.0.1。
  • Chartboost SDK 版本 9.6.0。

版本 9.6.0.0

  • 已经验证与 Chartboost SDK 版本 9.6.0 兼容。
  • 将已废弃的 GADMobileAds.sharedInstance.sdkVersion 方法替换为 GADMobileAds.sharedInstance.versionNumber
  • 添加了 GADMediationInterstitialAd 实现。

构建和测试所需版本:

  • Google 移动广告 SDK 10.14.0 版。
  • Chartboost SDK 版本 9.6.0。

版本 9.5.1.0

  • 已验证与 Chartboost SDK 版本 9.5.1 的兼容性。

构建和测试所需版本:

  • Google 移动广告 SDK 10.12.0 版。
  • Chartboost SDK 版本 9.5.1。

版本 9.4.0.0

  • 已验证与 Chartboost SDK 版本 9.4.0 的兼容性。

构建和测试所需版本:

  • Google 移动广告 SDK 10.7.0 版。
  • Chartboost SDK 版本 9.4.0。

版本 9.3.1.0

  • 已验证与 Chartboost SDK 版本 9.3.1 的兼容性。

构建和测试所需版本:

  • Google 移动广告 SDK 10.7.0 版。
  • Chartboost SDK 版本 9.3.1。

版本 9.3.0.0

  • 已验证与 Chartboost SDK 版本 9.3.0 的兼容性。
  • 现在,最低 iOS 版本要求为 11.0。
  • 现在需要 Google 移动广告 SDK 10.4.0 或更高版本。

构建和测试所需版本:

  • Google 移动广告 SDK 10.4.0 版。
  • Chartboost SDK 版本 9.3.0。

版本 9.2.0.0

  • 移除了 ChartboostAdapter 头文件中的 GADMChartboostExtras 导入。
  • 已验证与 Chartboost SDK 版本 9.2.0 的兼容性。
  • 现在需要 Google 移动广告 SDK 10.0.0 或更高版本。
  • 移除了对 armv7 架构的支持。
  • 现在,最低 iOS 版本要求为 11.0。

构建和测试所需版本:

  • Google 移动广告 SDK 10.0.0 版。
  • Chartboost SDK 版本 9.2.0。

版本 9.1.0.0

  • 已验证与 Chartboost SDK 版本 9.1.0 的兼容性。

构建和测试所需版本:

  • Google 移动广告 SDK 9.11.0 版。
  • Chartboost SDK 版本 9.1.0。

版本 9.0.0.0

  • 已验证与 Chartboost SDK 版本 9.0.0 的兼容性。
  • 已经验证与 Google 移动广告 SDK 9.10.0 版兼容。
  • 更新了适配器以使用 didRewardUser API。
  • 现在需要 Google 移动广告 SDK 9.8.0 或更高版本。

构建和测试所需版本:

  • Google 移动广告 SDK 9.10.0 版。
  • Chartboost SDK 版本 9.0.0。

版本 8.5.0.2

  • 已经验证与 Google 移动广告 SDK 9.0.0 版本兼容。
  • 现在需要 Google 移动广告 SDK 9.0.0 或更高版本。

构建和测试所需版本:

  • Google 移动广告 SDK 9.0.0 版。
  • Chartboost SDK 版本 8.5.0。

版本 8.5.0.1.0

  • 已验证与 Chartboost SDK 8.5.0 的兼容性,该版本在 CocoaPods 中对应于版本 8.5.0.1。

构建和测试所需版本

  • Google 移动广告 SDK 8.13.0 版。
  • Chartboost SDK 版本 8.5.0。

版本 8.5.0.0

  • 已经验证与 Chartboost SDK 8.5.0 兼容。

构建和测试所需版本

  • Google 移动广告 SDK 8.12.0 版。
  • Chartboost SDK 版本 8.5.0。

版本 8.4.2.0

  • 已验证与 Chartboost SDK 8.4.2 的兼容性。

构建和测试所需版本

  • Google 移动广告 SDK 8.6.0 版。
  • Chartboost SDK 版本 8.4.2。

版本 8.4.1.1

  • 放宽了对 Google 移动广告 SDK 8.0.0 或更高版本的依赖。

构建和测试所需版本

  • Google 移动广告 SDK 8.4.0 版。
  • Chartboost SDK 版本 8.4.1。

版本 8.4.1.0

  • 已验证与 Chartboost SDK 8.4.1 的兼容性。
  • 现在需要 Google 移动广告 SDK 8.1.0 或更高版本。

构建和测试所需版本

  • Google 移动广告 SDK 8.1.0 版。
  • Chartboost SDK 版本 8.4.1。

版本 8.4.0.1

  • 添加了标准化的适配器错误代码和消息。
  • 更新了适配器以使用 .xcframework 格式。
  • 现在需要 Google 移动广告 SDK 8.0.0 或更高版本。

构建和测试所需版本

  • Google 移动广告 SDK 8.0.0 版。
  • Chartboost SDK 版本 8.4.0。

版本 8.4.0.0

  • 已经验证与 Chartboost SDK 8.4.0 兼容。
  • 现在需要 Google 移动广告 SDK 7.68.0 或更高版本。

构建和测试所需版本

  • Google 移动广告 SDK 7.68.0 版。
  • Chartboost SDK 版本 8.4.0。

版本 8.3.1.0

  • 已验证与 Chartboost SDK 8.3.1 的兼容性。
  • 现在需要 Google 移动广告 SDK 7.66.0 或更高版本。
  • 现在,最低 iOS 版本要求为 10.0。
  • 更新了适配器,以支持自适应横幅广告请求。

构建和测试所需版本

  • Google 移动广告 SDK 7.66.0 版。
  • Chartboost SDK 版本 8.3.1。

版本 8.2.1.0

  • 经过验证,可与 Chartboost SDK 8.2.1 兼容。
  • 现在需要 Google 移动广告 SDK 7.64.0 或更高版本。
  • 现在,最低 iOS 版本要求为 9.0。

构建和测试所需版本

  • Google 移动广告 SDK 7.64.0 版。
  • Chartboost SDK 版本 8.2.1。

版本 8.2.0.0

  • 已验证与 Chartboost SDK 8.2.0 的兼容性。
  • 现在需要 Google 移动广告 SDK 7.61.0 或更高版本。

构建和测试所需版本

  • Google 移动广告 SDK 7.61.0 版。
  • Chartboost SDK 版本 8.2.0。

版本 8.1.0.1

  • 将最低要求的 Google 移动广告 SDK 版本更新为 7.60.0。
  • 更新了适配器以使用 Chartboost 的新 API,并移除了已废弃的 API。
  • 适配器现在支持使用相同的 Chartboost 位置加载多种格式的广告。
  • 如果未在 AdMob 或 Ad Manager 界面中替换奖励,激励广告的奖励值现在是 Chartboost 界面中指定的值,而不是 0

构建和测试所需版本

  • Google 移动广告 SDK 7.60.0 版。
  • Chartboost SDK 版本 8.1.0。

版本 8.1.0.0

  • 已经验证与 Chartboost SDK 8.1.0 兼容。
  • 将最低要求的 Google 移动广告 SDK 版本更新为 7.59.0。
  • 移除了对 i386 架构的支持。

构建和测试所需版本

  • Google 移动广告 SDK 7.59.0 版。
  • Chartboost SDK 版本 8.1.0。

版本 8.0.4.0

  • 已验证与 Chartboost SDK 8.0.4 的兼容性。

构建和测试所需版本

  • Google 移动广告 SDK 7.52.0 版。
  • Chartboost SDK 版本 8.0.4。

版本 8.0.1.1

  • 修复了请求横幅广告时未返回任何广告资源的问题。

版本 8.0.1.0

  • 已验证与 Chartboost SDK 8.0.1 的兼容性。
  • 添加了对请求横幅广告的支持。

版本 7.5.0.1

  • 添加了代码以正确初始化 Chartboost SDK。

版本 7.5.0.0

  • 已验证与 Chartboost SDK 7.5.0 的兼容性。
  • 更新了适配器以使用新的激励广告 API。
  • 更新了适配器以处理多个插页式广告请求。
  • 现在需要 Google 移动广告 SDK 7.42.2 或更高版本。

版本 7.3.0.0

  • 已经验证与 Chartboost SDK 7.3.0 兼容。

版本 7.2.0.1

  • 向适配器添加了 adapterDidCompletePlayingRewardBasedVideoAd: 回调。

版本 7.2.0.0

  • 已经验证与 Chartboost SDK 7.2.0 的兼容性。

版本 7.1.2.0

  • 已验证与 Chartboost SDK 7.1.2 的兼容性。

版本 7.1.1.0

  • 已验证与 Chartboost SDK 7.1.1 的兼容性。

版本 7.1.0.0

  • 已验证与 Chartboost SDK 7.1.0 的兼容性。

版本 7.0.4.0

  • 已验证与 Chartboost SDK 7.0.4 的兼容性。

版本 7.0.3.0

  • 已验证与 Chartboost SDK 7.0.3 的兼容性。

版本 7.0.2.0

  • 已验证与 Chartboost SDK 7.0.2 的兼容性。
  • 添加了对两个新 Chartboost 错误代码的支持。

版本 7.0.1.0

  • 已验证与 Chartboost SDK 7.0.1 的兼容性。

版本 7.0.0.0

  • 已验证与 Chartboost SDK 7.0.0 的兼容性。

版本 6.6.3.0

  • 已验证与 Chartboost SDK 6.6.3 的兼容性。
  • 移除了对“armv7s”架构的支持。
  • 修复了以下 bug:当发布商将 ChartboostAdapter.framework 作为导入非模块化 Chartboost SDK 的模块导入时,会在 Swift 中遇到编译问题。

版本 6.6.2.0

  • 已验证与 Chartboost SDK 6.6.2 的兼容性。

版本 6.6.1.0

  • 已验证与 Chartboost SDK 6.6.1 的兼容性。

版本 6.6.0.0

  • 已经验证与 Chartboost SDK 6.6.0 兼容。

版本 6.5.2.1

  • 启用了位码支持。
  • 现在,Chartboost 适配器以框架的形式分发。
  • 如需在项目中导入 ChartboostAdapter.framework,请务必在目标的“Build Settings”(构建设置)下将 Allow Non-modular Includes in Framework Modules 设置为 YES

版本 6.5.2.0

  • 将版本命名系统更改为 [Chartboost SDK 版本].[适配器补丁版本]。
  • 将所需的最低 Chartboost SDK 版本更新为 v6.5.1。
  • 将最低要求的 Google 移动广告 SDK 版本更新为 v7.10.1。
  • 修复了导致 Chartboost 广告无法支持多个展示位置的 bug。
  • 现在,当插页式广告即将关闭时,应用会收到 interstitialWillDismissScreen: 回调。
  • 现在,当用户打开基于激励的视频广告时,应用会收到 rewardBasedVideoAdDidOpen: 回调。

版本 1.1.0

  • 从 Chartboost 附加信息中移除了 Chartboost 广告位置。现在,在 AdMob 控制台中配置 Chartboost 中介时,需要指定广告位置。

版本 1.0.0

  • 初始版本。支持激励视频广告和插页式广告。