本指南介绍了如何使用 Google 移动广告 SDK 使用 AdMob 中介加载和展示来自 DT 广告交易平台的广告,并涵盖广告瀑布流集成。其中介绍了如何将 DT Exchange 添加到广告单元的中介配置,以及如何将 DT Exchange SDK 和适配器集成到 iOS 应用中。
支持的集成和广告格式
DT Exchange 的中介适配器具有以下功能:
集成 | |
---|---|
出价 | |
瀑布 | |
表现形式 | |
横幅 | |
插页式广告 | |
激励广告 | |
原生 |
要求
- iOS 部署目标为 12.0 或更高版本
最新版 Google 移动广告 SDK
完成中介入门指南
第 1 步:在 DT Exchange 界面中设置配置
添加新的应用和广告展示位置
点击添加应用按钮以添加应用。
选择您的平台,填写表单的其余部分,然后点击添加展示位置。
在标记为为展示位置命名的字段中输入新展示位置的名称,然后从下拉列表中选择所需的展示位置类型。最后,点击保存展示位置。
应用 ID 和展示位置 ID
将鼠标悬停在左侧导航栏上,即可打开该导航栏。然后,点击左侧菜单中的应用。
在应用管理页面上,记下应用旁边的应用 ID。
选择您的应用,前往展示位置标签页,然后点击展示位置名称旁边的复制图标。记下展示位置 ID。
发布商 ID、使用方密钥和使用方密码
点击左侧菜单中的用户名,然后选择用户个人资料。
记下发布商 ID、使用方密钥和使用方 Secret,因为您在下一步中需要用到这些信息。
第 2 步:在 AdMob 界面中设置 DT Exchange 需求
为广告单元配置中介设置
您需要将 DT Exchange 添加到广告单元的中介配置中。
首先,登录您的 AdMob 账号。接下来,前往中介标签页。如果您有现有中介组要修改,请点击该中介组的名称进行修改,然后跳至将 DT 广告交易平台添加为广告来源。
如需创建新的中介组,请选择创建中介组。
输入广告格式和平台,然后点击继续。
为中介组命名,然后选择要定位的地理位置。接下来,将中介组状态设为启用,然后点击添加广告单元。
将此中介组与一个或多个现有 AdMob 广告单元相关联。然后,点击完成。
您现在应该会看到广告单元卡片,其中填充了您选择的广告单元:
将 DT Exchange 添加为广告来源
在广告来源部分的广告瀑布流卡片下,选择添加广告来源。然后选择 DT Exchange。
选择 DT Exchange,然后启用 Optimize 开关。输入您在上一部分中获取的发布商 ID、使用方密钥和使用方密钥,以便为 DT Exchange 设置广告来源优化。 然后,为 DT 广告交易平台输入有效每千次展示费用值,然后点击继续。
如果您已经有 DT Exchange 映射,可以选择该映射。 否则,请点击添加映射。
接下来,输入您在上一部分中获取的应用 ID 和展示位置 ID。然后,点击完成。
将 DT Exchange (Fyber Monetization) 添加到 GDPR 和美国州级法规广告合作伙伴名单中
请按照 GDPR 设置和 美国州级法规设置中的步骤,将 DT Exchange (Fyber Monetization) 添加到 AdMob 界面中的 GDPR 和美国州级法规广告合作伙伴名单中。
第 3 步:导入 DT Exchange SDK 和适配器
使用 CocoaPods(推荐)
将以下代码行添加到项目的 Podfile 中:
pod 'GoogleMobileAdsMediationFyber'
在命令行中运行以下命令:
pod install --repo-update
手动集成
- 下载最新版本的 DT Exchange SDK for iOS,并将以下框架关联到您的项目:
IASDKCore.framework
IASDKMRAID.framework
IASDKVideo.framework
- 从更新日志中的下载链接下载最新版本的 DT Exchange 适配器,并在项目中关联
FyberAdapter.framework
。 - 将以下框架添加到您的项目中:
libxml2.2.tbd
第 4 步:在 DT Exchange SDK 中实现隐私设置
欧盟地区用户意见征求和《一般数据保护条例》(GDPR)
根据 Google 《欧盟地区用户意见征求政策》,您必须确保向位于欧洲经济区 (EEA) 的用户披露相关信息并征求他们的意见,说明您将如何使用设备标识符和个人数据。此政策反映了欧盟《电子隐私指令》和《一般数据保护条例》(GDPR) 的要求。在征求用户意见时,您必须指明中介链中可能会收集、接收或使用个人数据的每个广告联盟,并提供有关每个广告联盟使用情况的信息。Google 目前无法自动将用户的意见征求选择传递给此类广告联盟。
DT Exchange 包含一个 API,可让您将用户意见征求转发到其 SDK。以下示例代码展示了如何手动将意见征求信息传递给 DT Exchange SDK。如果您选择手动将意见征求信息传递给 DT 广告交易平台 SDK,建议您先调用此代码,然后再通过 Google 移动广告 SDK 请求广告。
Swift
import IASDKCore
// ...
IASDKCore.sharedInstance().gdprConsent = IAGDPRConsentType.given
IASDKCore.sharedInstance().gdprConsentString = "myGdprConsentString"
Objective-C
#import <IASDKCore/IASDKCore.h>
// ...
[IASDKCore.sharedInstance setGDPRConsent:YES];
[IASDKCore.sharedInstance setGDPRConsentString:@"myGdprConsentString"];
如需了解详情以及该方法中可能提供的值,请访问 DT Exchange 的 GDPR 资源页面和 GDPR 实现指南。
美国州级隐私保护法律
美国各州隐私保护法律 要求向用户提供选择不“出售”其“个人信息”(该法律对这些术语进行了定义)的权利,并要求“出售”方在首页醒目位置提供“Do Not Sell My Personal Information”(不出售我的个人信息)链接,以供用户选择。美国州级隐私保护法律合规指南提供了为 Google 广告投放启用受限的数据处理的功能,但 Google 无法将此设置应用于中介链中的每个广告网络。因此,您必须找出中介链中可能参与销售个人信息的每个广告网络,并遵循每个广告网络的指南,以确保合规。
DT Exchange 包含一个 API,可让您将用户意见征求转发到其 SDK。以下示例代码展示了如何手动将意见征求信息传递给 DT Exchange SDK。如果您选择手动将意见征求信息传递给 DT 广告交易平台 SDK,建议您先调用此代码,然后再通过 Google 移动广告 SDK 请求广告。
Swift
import IASDKCore
// ...
IASDKCore.sharedInstance().ccpaString = "myCCPAConsentString"
Objective-C
#import <IASDKCore/IASDKCore.h>
// ...
[IASDKCore.sharedInstance setCCPAString:@"myCCPAConsentString"];
如需了解详情以及该方法中可能提供的值,请访问 DT Exchange 的 CCPA 资源页面和 CCPA 实现指南。
第 5 步:添加所需代码
SKAdNetwork 集成
按照 DT Exchange 文档中的说明,将 SKAdNetwork 标识符添加到项目的 Info.plist
文件中。
第 6 步:测试您的实现
启用测试广告
请务必为 AdMob 注册测试设备。
验证测试广告
如需验证您是否在接收来自 DT Exchange 的测试广告,请在广告检查器中使用 DT Exchange(广告瀑布流)广告来源启用单一广告来源测试。
可选步骤
网络专用参数
DT Exchange 适配器支持其他请求参数,可使用 GADMAdapterFyberExtras()
传递给适配器。适配器会在软件包中查找以下键:
请求参数和值 | |
---|---|
setUserData 用户的年龄、性别和邮政编码。 |
IAUserData |
setMuteAudio
|
Boolean。将视频静音或取消静音 |
以下代码示例展示了如何设置这些广告请求参数:
Swift
let userData = IAUserData.build({ builder in
builder.age = 23
builder.gender = IAUserGenderType.male
builder.zipCode = "1234"
}];
let request = GADRequest()
let extras = GADMAdapterFyberExtras()
extras.userData = userData
extras.muteAudio = true
request.register(extras)
Objective-C
IAUserData *userData = [IAUserData build:^(id<IAUserDataBuilder> _Nonnull builder) {
builder.age = 23;
builder.gender = IAUserGenderTypeMale;
builder.zipCode = @"1234";
}];
GADRequest *request = [GADRequest request];
GADMAdapterFyberExtras *extras = [[GADMAdapterFyberExtras alloc] init];
extras.userData = userData;
extras.muteAudio = YES;
[request registerAdNetworkExtras:extras];
如需了解详情,请参阅 DT Exchange 集成指南。
错误代码
如果适配器未能从 DT Exchange 收到广告,您可以使用以下类下的 GADResponseInfo.adNetworkInfoArray
检查广告响应的根本错误:
GADMediationAdapterFyber
以下是 DT Exchange 适配器在广告加载失败时抛出的代码和随附消息:
错误代码 | 原因 |
---|---|
0-10 | DT Exchange SDK 返回了错误。如需了解详情,请参阅文档。 |
101 | AdMob 界面中配置的 DT Exchange 服务器参数缺失/无效。 |
102 | 请求的广告尺寸与 DT Exchange 支持的横幅广告尺寸不符。 |
103 | 广告对象已被使用,因此未能展示广告。 |
104 | 由于广告未准备就绪,未能展示 DT Exchange 广告。 |
105 | DT Exchange SDK 返回了初始化错误。 |
DT Exchange iOS 中介适配器变更日志
版本 8.3.2.1
- 移除了已废弃的关键字用法。
- 修复了导致插页式广告和激励广告消失并显示空白屏幕的 bug。
- 更新了
CFBundleShortVersionString
,使其包含三个组件,而不是四个。
构建和测试所需版本:
- Google 移动广告 SDK 版本 11.10.0。
- DT Exchange SDK 版本 8.3.2。
版本 8.3.2.0
- 已验证与 DT Exchange SDK 版本 8.3.2 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 11.8.0 版。
- DT Exchange SDK 版本 8.3.2。
版本 8.3.1.0
- 已验证与 DT Exchange SDK 8.3.1 版的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 11.6.0 版。
- DT Exchange SDK 版本 8.3.1。
版本 8.3.0.0
- 已验证与 DT Exchange SDK 版本 8.3.0 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 11.5.0 版。
- DT Exchange SDK 版本 8.3.0。
版本 8.2.8.0
- 已验证与 DT Exchange SDK 版本 8.2.8 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 11.3.0 版。
- DT Exchange SDK 版本 8.2.8。
版本 8.2.7.0
- 已验证与 DT Exchange SDK 版本 8.2.7 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 11.2.0 版。
- DT Exchange SDK 版本 8.2.7。
版本 8.2.6.1
- 在激励广告中添加了
didFailToPresentWithError
回调。 - 在插页式广告和激励广告中添加了
IAAdDidExpire
委托方法。 - 现在,最低 iOS 版本要求为 12.0。
- 现在需要 Google 移动广告 SDK 11.0 或更高版本。
- 在
DTExchangeAdapter.xcframework
中的框架中添加了Info.plist
。
构建和测试所需版本:
- Google 移动广告 SDK 版本 11.0.1。
- DT Exchange SDK 版本 8.2.6。
版本 8.2.6.0
- 已经验证与 DT Exchange SDK 8.2.6 版兼容。
- 从横幅广告和插页式广告实现中移除了已废弃的
willBackgroundApplication
委托方法。
构建和测试所需版本:
- Google 移动广告 SDK 10.14.0 版。
- DT Exchange SDK 版本 8.2.6。
版本 8.2.5.0
- 已验证与 DT Exchange SDK 版本 8.2.5 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 10.14.0 版。
- DT Exchange SDK 版本 8.2.5。
版本 8.2.4.0
- 已验证与 DT Exchange SDK 版本 8.2.4 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 10.9.0 版。
- DT Exchange SDK 版本 8.2.4。
版本 8.2.3.0
- 已验证与 DT Exchange SDK 版本 8.2.3 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 10.7.0 版。
- DT Exchange SDK 版本 8.2.3。
版本 8.2.2.0
- 已验证与 DT Exchange SDK 版本 8.2.2 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 10.5.0 版。
- DT Exchange SDK 版本 8.2.2。
版本 8.2.1.0
- 已验证与 DT Exchange SDK 8.2.1 版的兼容性。
- 移除了对
armv7
架构的支持。 - 现在,最低 iOS 版本要求为 11.0。
- 现在需要 Google 移动广告 SDK 10.4.0 或更高版本。
构建和测试所需版本:
- Google 移动广告 SDK 10.4.0 版。
- DT Exchange SDK 版本 8.2.1。
版本 8.2.0.0
- 已经验证与 DT Exchange SDK 版本 8.2.0 兼容。
构建和测试所需版本:
- Google 移动广告 SDK 10.2.0 版。
- DT Exchange SDK 版本 8.2.0。
版本 8.1.9.1
- 现在需要 Google 移动广告 SDK 10.0.0 或更高版本。
构建和测试所需版本:
- Google 移动广告 SDK 10.0.0 版。
- DT Exchange SDK 版本 8.1.9。
版本 8.1.9.0
- 移除了已废弃的性别、生日和位置中介 API。
- 已验证与 DT Exchange SDK 8.1.9 版的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 9.14.0 版。
- DT Exchange SDK 版本 8.1.9。
版本 8.1.7.0
- 已验证与 DT Exchange SDK 8.1.7 版的兼容性。
- 适配器已更名为“DT Exchange”。
构建和测试所需版本:
- Google 移动广告 SDK 9.13.0 版。
- DT Exchange SDK 版本 8.1.7。
版本 8.1.6.0
- 添加了对在
GADMAdapterFyberExtras
类中传递muteAudio
extra 的支持。 - 更新了适配器以使用
didRewardUser
API。 - 现在需要 Google 移动广告 SDK 9.8.0 或更高版本。
- 已经验证与 Fyber Marketplace SDK 版本 8.1.6 兼容。
构建和测试所需版本:
- Google 移动广告 SDK 9.11.0 版。
- Fyber Marketplace SDK 版本 8.1.6。
版本 8.1.5.0
- 已验证与 Fyber Marketplace SDK 8.1.5 版本的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 9.5.0 版。
- Fyber Marketplace SDK 版本 8.1.5。
版本 8.1.4.0
- 已验证与 Fyber Marketplace SDK 版本 8.1.4 的兼容性。
- 添加了对 arm64 模拟器架构的支持。
构建和测试所需版本:
- Google 移动广告 SDK 9.1.0 版。
- Fyber Marketplace SDK 版本 8.1.4。
版本 8.1.3.1
- 已经验证与 Google 移动广告 SDK 9.0.0 版本兼容。
- 现在需要 Google 移动广告 SDK 9.0.0 或更高版本。
构建和测试所需版本:
- Google 移动广告 SDK 9.0.0 版。
- Fyber Marketplace SDK 版本 8.1.3。
版本 8.1.3.0
- 已验证与 Fyber Marketplace SDK 版本 8.1.3 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 8.13.0 版。
- Fyber Marketplace SDK 版本 8.1.3。
版本 8.1.2.0
- 已经验证与 Fyber Marketplace SDK 版本 8.1.2 兼容。
构建和测试所需版本:
- Google 移动广告 SDK 8.13.0 版。
- Fyber Marketplace SDK 版本 8.1.2。
版本 8.1.1.0
- 已经验证与 Fyber Marketplace SDK 版本 8.1.1 兼容。
构建和测试所需版本:
- Google 移动广告 SDK 8.12.0 版。
- Fyber Marketplace SDK 版本 8.1.1。
版本 8.1.0.0
- 已验证与 Fyber Marketplace SDK 8.1.0 版本的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 8.12.0 版。
- Fyber Marketplace SDK 版本 8.1.0。
版本 8.0.0.0
- 已经验证与 Fyber Marketplace SDK 8.0.0 版本兼容。
构建和测试所需版本:
- Google 移动广告 SDK 8.12.0 版。
- Fyber Marketplace SDK 版本 8.0.0。
版本 7.9.0.0
- 已验证与 Fyber Marketplace SDK 7.9.0 版本的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 8.11.0 版。
- Fyber Marketplace SDK 版本 7.9.0。
版本 7.8.9.0
- 已验证与 Fyber Marketplace SDK 7.8.9 版的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 8.10.0 版。
- Fyber Marketplace SDK 版本 7.8.9。
版本 7.8.8.1
- 将广告事件
didEndVideo
移到了激励广告回调IAAdDidReward
。
构建和测试所需版本:
- Google 移动广告 SDK 8.9.0 版。
- Fyber Marketplace SDK 版本 7.8.8。
版本 7.8.8.0
- 现在需要的最低 iOS 版本为 10.0。
- 已经验证与 Fyber Marketplace SDK 版本 7.8.8 兼容。
构建和测试所需版本:
- Google 移动广告 SDK 8.9.0 版。
- Fyber Marketplace SDK 版本 7.8.8。
版本 7.8.7.0
- 已验证与 Fyber Marketplace SDK 版本 7.8.7 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 8.8.0 版。
- Fyber Marketplace SDK 版本 7.8.7。
版本 7.8.6.0
- 已经验证与 Fyber Marketplace SDK 版本 7.8.6 兼容。
构建和测试所需版本:
- Google 移动广告 SDK 8.5.0 版。
- Fyber Marketplace SDK 版本 7.8.6。
版本 7.8.5.0
- 已验证与 Fyber Marketplace SDK 7.8.5 版的兼容性。
- 现在需要针对 Xcode 12.5 或更高版本进行构建。
构建和测试所需版本:
- Google 移动广告 SDK 8.5.0 版。
- Fyber Marketplace SDK 版本 7.8.5。
版本 7.8.1.0
- 已验证与 Fyber Marketplace SDK 7.8.1 版的兼容性。
- 放宽了对 Google 移动广告 SDK 8.0.0 或更高版本的依赖。
- 添加了标准化的适配器错误代码和消息。
- 更新了适配器以使用
.xcframework
格式。
构建和测试所需版本:
- Google 移动广告 SDK 8.0.0 版。
- Fyber Marketplace SDK 版本 7.8.1。
版本 7.8.0.0
- 已验证与 Fyber Marketplace SDK 7.8.0 版本的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 7.69.0 版。
- Fyber Marketplace SDK 版本 7.8.0。
版本 7.7.3.0
- 已验证与 Fyber Marketplace SDK 7.7.3 版本的兼容性。
- 现在需要 Google 移动广告 SDK 7.69.0 或更高版本。
构建和测试所需版本:
- Google 移动广告 SDK 7.69.0 版。
- Fyber Marketplace SDK 版本 7.7.3。
版本 7.7.2.0
- 已验证与 Fyber Marketplace SDK 版本 7.7.2 的兼容性。
- 现在需要 Google 移动广告 SDK 7.67.0 或更高版本。
构建和测试所需版本:
- Google 移动广告 SDK 7.67.0 版。
- Fyber Marketplace SDK 版本 7.7.2。
版本 7.7.1.0
- 已验证与 Fyber Marketplace SDK 7.7.1 版的兼容性。
- 现在需要 Google 移动广告 SDK 7.66.0 或更高版本。
构建和测试所需版本:
- Google 移动广告 SDK 7.66.0 版。
- Fyber Marketplace SDK 版本 7.7.1。
版本 7.6.4.0
- 已经验证与 Fyber Marketplace SDK 7.6.4 版本兼容。
- 现在需要 Google 移动广告 SDK 7.65.0 或更高版本。
- 添加了 GADMAdapterFyberExtras 类,以便发布商将关键字和 userData 传递给 Fyber Marketplace SDK。
构建和测试所需版本:
- Google 移动广告 SDK 7.65.0 版。
- Fyber Marketplace SDK 版本 7.6.4。
版本 7.6.3.0
- 已验证与 Fyber Marketplace SDK 版本 7.6.3 的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 7.64.0 版。
- Fyber Marketplace SDK 版本 7.6.3。
版本 7.6.2.0
- 已经验证与 Fyber Marketplace SDK 版本 7.6.2 兼容。
- 现在需要 Google 移动广告 SDK 7.64.0 或更高版本。
构建和测试所需版本:
- Google 移动广告 SDK 7.64.0 版。
- Fyber Marketplace SDK 版本 7.6.2。
版本 7.6.0.0
- 已验证与 Fyber Marketplace SDK 7.6.0 版本的兼容性。
- 现在需要 Google 移动广告 SDK 7.62.0 或更高版本。
- 更新了适配器,以支持内嵌自适应横幅广告请求。
- 添加了对 HTML 激励广告的支持。
- 添加了新的激励回调:IAAdDidReward(适用于激励视频广告和激励型 HTML 广告)。IAVideoCompleted 不再用于奖励。
构建和测试所需版本:
- Google 移动广告 SDK 7.62.0 版。
- Fyber Marketplace SDK 版本 7.6.0。
版本 7.5.6.1
- 暂时移除了 Fyber Marketplace SDK 专用日志记录。
构建和测试所需版本:
- Google 移动广告 SDK 7.60.0 版。
- Fyber Marketplace SDK 版本 7.5.6。
版本 7.5.6.0
- 已验证与 Fyber Marketplace SDK 7.5.6 版的兼容性。
- 将最低要求的 Google 移动广告 SDK 版本更新为 7.60.0。
构建和测试所需版本:
- Google 移动广告 SDK 7.60.0 版。
- Fyber Marketplace SDK 版本 7.5.6。
版本 7.5.5.0
- 已验证与 Fyber Marketplace SDK 7.5.5 版本的兼容性。
- 将最低要求的 Google 移动广告 SDK 版本更新为 7.59.0。
构建和测试所需版本:
- Google 移动广告 SDK 7.59.0 版。
- Fyber Marketplace SDK 版本 7.5.5。
版本 7.5.4.0
- 已验证与 Fyber Marketplace SDK 7.5.4 版本的兼容性。
- 移除了对 i386 架构的支持。
构建和测试所需版本:
- Google 移动广告 SDK 7.57.0 版。
- Fyber Marketplace SDK 版本 7.5.4。
版本 7.5.3.0
- 已验证与 Fyber Marketplace SDK 7.5.3 版的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 7.55.0 版。
- Fyber Marketplace SDK 版本 7.5.3。
版本 7.5.1.0
- 已验证与 Fyber Marketplace SDK 7.5.1 版的兼容性。
- 修复了初始化 Fyber SDK 时发生的崩溃问题。
构建和测试所需版本:
- Google 移动广告 SDK 7.55.0 版。
- Fyber Marketplace SDK 版本 7.5.1。
版本 7.5.0.0(已废弃)
- 此版本已被移除。请使用 7.5.1.0 或更高版本。
- 已验证与 Fyber Marketplace SDK 7.5.0 版本的兼容性。
- 如果 Fyber SDK 尚未初始化,适配器现在会在发出广告请求之前初始化 Fyber SDK。
构建和测试所需版本:
- Google 移动广告 SDK 7.53.0 版。
- Fyber Marketplace SDK 版本 7.5.0。
版本 7.4.0.0
- 初始版本!
- 新增了对横幅广告、插页式广告和激励广告格式的支持。
构建和测试所需版本:
- Google 移动广告 SDK 7.52.0 版。
- Fyber Marketplace SDK 版本 7.4.0。