本指南介绍了如何使用 Google Mobile Ads SDK 通过中介加载和展示来自 BidMachine 的广告,其中涵盖了出价集成。如何将 BidMachine 添加到广告单元的中介配置,以及如何将 BidMachine SDK 和适配器集成到 iOS 应用中。
支持的集成和广告格式
BidMachine 的中介适配器具有以下功能:
| 集成 | |
|---|---|
| 出价 | |
| 瀑布 | 1 |
| 表现形式 | |
| 应用启动 | |
| 横幅 | |
| 插页式广告 | |
| 激励广告 | |
| 插页式激励广告 | |
| 原生 | |
1 Waterfall 集成目前处于非公开 Beta 版阶段,请与您的客户经理联系,申请访问权限。
要求
- iOS 部署目标版本为 13.0 或更高版本
“Google Mobile Ads SDK”的最新视频
完成中介入门指南阅读。
第 1 步:在 BidMachine 界面中设置配置
登录您的 BidMachine 账号信息中心。
创建新的展示位置
前往来源标签页,然后在来源表格下选择修改按钮。
系统会显示您拥有的所有展示位置的列表。如需创建新的展示位置,请点击对话框中的添加展示位置按钮。
填写表单并点击保存。
最后,记下展示位置 ID。
更新 app-ads.txt
应用授权卖方 (app-ads.txt) 是一项 IAB Tech Lab 计划,有助于确保只通过您认定的授权渠道销售您的应用广告资源。为避免损失大量广告收入,您需要实施 app-ads.txt 文件。
如果您尚未完成此项操作,请为 Ad Manager 创建 app-ads.txt 文件。
如需为 BidMachine 实现 app-ads.txt,请从信息中心前往 app-ads.txt 标签页。然后,复制该列表并将其附加到网站的 app-ads.txt 文件中。
第 2 步:在 Ad Manager 界面中设置 BidMachine 需求
登录您的 Ad Manager 账号。
在“公司”中添加 BidMachine
出价
出价集成不需要执行此步骤。
瀑布
依次前往管理 > 公司,然后点击所有公司标签页中的新公司按钮。选择广告联盟。

选择 BidMachine 作为广告联盟,输入唯一的名称,然后启用中介。
您无需输入用户名或密码。完成后,点击保存。

启用安全信号共享
出价
依次前往管理 > 全局设置。前往 Ad Exchange 账号设置标签页,然后查看并开启安全信号共享。点击保存。

瀑布
对于瀑布流集成,则无需执行此步骤。
在出价请求中共享安全信号
出价
依次前往广告资源 > 安全信号。在安全信号下,搜索 BidMachineToken,然后将启用应用集成切换为开启状态。

点击保存。
瀑布
对于瀑布流集成,则无需执行此步骤。
允许出于 SDK 出价目的共享安全信号
出价
依次前往投放 > 需求来源渠道设置。在默认设置标签页中,将允许共享安全信号切换到开启状态,以便进行 SDK 出价。

点击保存。
瀑布
对于瀑布流集成,则无需执行此步骤。
配置 BidMachine 出价
出价
依次前往投放 > 出价方,然后点击前往“SDK 出价”页面。

点击新增出价方。

选择 BidMachine 作为出价方。

点击继续即可为此出价方启用 SDK 出价。

点击完成。
瀑布
对于瀑布流集成,则无需执行此步骤。
配置广告单元映射
出价
依次前往投放 > 出价方,然后点击前往“SDK 出价”页面。

选择 BidMachine 的公司。

前往广告单元映射标签页,然后点击新建广告单元映射。

选择特定广告单元。选择广告单元和格式,选择移动应用作为广告资源类型,并选择您的移动应用。然后,输入在上一部分获得的来源 ID 和展示位置 ID。
最后,点击保存。

瀑布
依次前往投放 > 收益组,然后点击新建收益组按钮。选择您的移动应用。

向下滚动,然后点击添加收益合作伙伴。

选择您在上一部分中为 BidMachine 创建的公司。 选择移动 SDK 中介作为集成类型,iOS 作为平台,有效作为状态。
输入您在上一部分中获得的展示位置 ID 和默认每千次展示费用值。点击保存。

将 BidMachine 添加到 GDPR 和美国州级法规广告合作伙伴名单中
请按照欧洲法规设置和美国州级法规设置中的步骤,将 BidMachine 添加到 Ad Manager 界面内的欧洲法规和美国州级法规广告合作伙伴名单中。
第 3 步:导入 BidMachine SDK 和适配器
使用 Swift Package Manager
在继续之前,您必须拥有支持的最低适配器版本 3.6.0.0。
若要向项目添加软件包依赖项,请按照以下步骤操作:
在 Xcode 中,前往 File > Add Package Dependencies...。
在显示的提示中,搜索以下软件包网址:
https://github.com/googleads/googleads-mobile-ios-mediation-bidmachine.git在依赖项规则中,选择分支。
在文本字段中,输入
main。
使用 CocoaPods
将以下行添加到项目的 Podfile:
pod 'GoogleMobileAdsMediationBidMachine'在命令行中,运行以下代码:
pod install --repo-update
手动集成
下载最新版本的 BidMachine SDK for iOS,并将项目中的所有
.xcframework文件和软件包关联起来。从更改日志中的下载链接下载最新版本的 BidMachine 适配器,并在项目中关联
BidMachineAdapter.xcframework。
第 4 步:在 BidMachine SDK 上实现隐私设置
为了遵守 Google 的《欧盟地区用户意见征求政策》,您必须向欧洲经济区 (EEA)、英国和瑞士的用户披露某些信息,并征得他们同意,才能在法律要求的情况下使用 Cookie 或其他本地存储空间,以及收集、分享和使用个人数据以实现广告个性化。此政策反映了欧盟《电子隐私指令》和《一般数据保护条例》(GDPR) 的要求。您要负责验证用户意见是否已传播到中介链中的每个广告来源。Google 无法自动将用户意见传递给此类广告资源网。
BidMachine 会自动读取由意见征求管理平台(包括 UMP SDK)设置的 GDPR 意见征求。如需了解详情,请参阅 GDPR。
美国州级隐私保护法律
美国各州隐私保护法律要求向用户提供选择拒绝“出售”其“个人信息”(该法律中对这些术语做出了定义)的权利,“出售”方须在首页醒目位置提供“Do Not Sell My Personal Information”(不出售我的个人信息)链接,以供这些用户选择。美国州级隐私保护法律合规性指南可让您为 Google 广告投放启用受限的数据处理,但 Google 无法将此设置应用于您的中介链中的每个广告联盟。因此,您必须确定中介链中可能参与个人信息出售的每个广告联盟,并遵循这些广告联盟的指南来确保合规性。
BidMachine 会自动读取由意见征求管理平台(包括 UMP SDK)设置的 GPP 意见征求。如需了解详情,请参阅 GPP。
第 5 步:添加必需的代码
实现 SKAdNetwork
按照 BidMachine 的文档将 SKAdNetwork 标识符添加到项目的 Info.plist 文件中。
第 6 步:测试您的实现
启用测试广告
确保针对 Ad Manager 注册测试设备。
按照 BidMachine 文档中针对 iOS 的说明操作,以启用 BidMachine 的测试模式。
验证测试广告
若要验证您是否能收到来自 BidMachine 的测试广告,请在广告检查器中启用单个广告来源测试,并选择 BidMachine (Bidding)(BidMachine [出价])作为广告来源。
可选步骤
原生广告
广告呈现
BidMachine 适配器以 GADNativeAd 对象的形式返回其原生广告。它会为 GADNativeAd 填充以下字段。
| 字段 | BidMachine 适配器始终包含的资源 |
|---|---|
| 标题 | |
| 图片 | |
| 正文 | |
| 图标 | |
| 号召性用语 | |
| 星级 | |
| 商店 | |
| 价格 | |
| 广告客户 |
错误代码
如果适配器未能收到来自 BidMachine 的广告,您可以使用 GADResponseInfo.adNetworkInfoArray 来检查广告响应中归属于以下类的底层错误:
GADMediationAdapterBidMachine
以下是当广告加载失败时,BidMachine 适配器会抛出的代码和随附的消息:
| 错误代码 | 网域 | 原因 |
|---|---|---|
| 101 | com.google.mediation.bidmachine | 服务器配置缺少必需的发布商 ID。 |
| 102 | com.google.mediation.bidmachine | 出价信号收集请求失败,原因是 RTB 参数不包含广告格式或指定格式不受支持。 |
| 103 | com.google.mediation.bidmachine | 加载广告的广告配置无效。 |
| 104 | com.google.mediation.bidmachine | BidMachine SDK 向横幅广告的 BidMachineAdProtocol didLoadAd 委托方法返回了非横幅广告。绝不应发生。 |
| 105 | com.google.mediation.bidmachine | 全屏广告尚未准备好展示。 |
| 106 | com.google.mediation.bidmachine | Bid Machine SDK 向原生广告的 BidMachineAdProtocol didLoadAd 委托方法返回了非原生广告。绝不应发生。 |
| 107 | com.google.mediation.bidmachine | 未能加载某个原生广告图片来源。 |
BidMachine iOS 中介适配器变更日志
3.7.0.0 版
- 已验证与 BidMachine SDK 3.7.0 版的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 13.4.0 版。
- BidMachine SDK 3.7.0 版。
3.6.1.1 版
- 适配器现在会将
ageRestrictedTreatmentGoogle 移动广告 SDK 标志转发给 BidMachine SDK 的 COPPA API。 - 将 BidMachine 适配器和单元测试升级到 Swift 6。
构建和测试所需版本:
- Google 移动广告 SDK 13.3.0 版。
- BidMachine SDK 3.6.1 版。
3.6.1.0 版
- 已验证与 BidMachine SDK 3.6.1 版的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 13.2.0 版。
- BidMachine SDK 3.6.1 版。
3.6.0.0 版
- 已验证与 BidMachine SDK 3.6.0 版的兼容性。
- 重构了 BidMachine 横幅广告加载和原生广告图片处理。
构建和测试所需版本:
- Google 移动广告 SDK 13.1.0 版。
- BidMachine SDK 3.6.0 版。
3.5.1.2 版
- 将 Google 移动广告 SDK 依赖项更新到了版本 13.0.0。
构建和测试所需版本:
- Google 移动广告 SDK 13.0.0 版。
- BidMachine SDK 3.5.1 版。
3.5.1.1 版
- 将 CocoaPods 最低 iOS 版本更新为
13.0。 - 添加了对将
tagForUnderAgeOfConsentGoogle 移动广告 SDK 参数转发给 BidMachine SDK 的支持。 - 修改了
BidMachineAdDelegate一致性部分,以与 BidMachine SDK 回调行为保持一致。
构建和测试所需版本:
- Google 移动广告 SDK 13.0.0 版。
- BidMachine SDK 3.5.1 版。
3.5.1.0 版
- 已验证与 BidMachine SDK 3.5.1 版的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 12.14.0 版。
- BidMachine SDK 3.5.1 版。
3.5.0.0 版
- 已验证与 BidMachine SDK 3.5.0 版的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 12.12.0 版。
- BidMachine SDK 3.5.0 版。
3.4.0.2 版
- 为横幅广告、插页式广告、激励广告和原生广告格式添加了瀑布流支持。
- 从
BidMachineAdapterExtras中移除了isTestMode静态属性。 - 为瀑布流横幅广告添加了横幅广告尺寸验证。
构建和测试所需版本:
- Google 移动广告 SDK 12.12.0 版。
- BidMachine SDK 3.4.0 版。
3.4.0.1 版
- 现在,您可以通过
GADMediationAdapterBidMachineExtras.isTestMode属性在 Objective-C 中使用测试模式。
构建和测试所需版本:
- Google 移动广告 SDK 12.0.0 版。
- BidMachine SDK 3.4.0 版。
3.4.0.0 版
- 初始版本。
- 为横幅广告、插页式广告、激励广告和原生广告格式添加了出价支持。
- 已验证与 BidMachine SDK 3.4.0 版的兼容性。
构建和测试所需版本:
- Google 移动广告 SDK 12.8.0 版。
- BidMachine SDK 3.4.0 版。