从AppMeasurement迁移到Web SDK
此实施路径涉及系统地迁移方法,以便从AppMeasurement实施迁移到Web SDK JavaScript库实施。 其他实施路径将在单独的页面上介绍:
- Analytics扩展到Web SDK扩展:采用一种流畅、有条不紊的方法从Adobe Analytics标记扩展移动到Web SDK标记扩展。 在您的组织准备好使用Adobe Experience Platform服务(如Customer Journey Analytics)之前,此方法会抑制使用XDM的需求。 使用
data
对象而不是xdm
对象将数据发送到Adobe。 - Web SDK JavaScript库:使用Web SDK JavaScript库(
alloy.js
)的全新Web SDK安装。 自行管理实施,而不是使用标记UI。 它需要Adobe Analytics ExperienceEvent字段组,其中包括要包含在XDM架构中的典型Analytics变量。 - Web SDK标记扩展:一个全新的Web SDK安装,您可以在其中使用Adobe Experience Platform数据收集中的标记管理实施。 它需要Adobe Analytics ExperienceEvent字段组,其中包括要包含在XDM架构中的典型Analytics变量。
此实施路径的优缺点
使用此迁移方法既有优点,也有缺点。 仔细权衡每个选项,以确定哪种方法最适合您的组织。
- 使用您现有的实施:虽然此方法需要一些实施更改,但它不需要从头开始的全新实施。 您可以使用现有的数据层和代码,只需对实施逻辑进行最低限度的更改即可。
- 不需要架构:对于迁移到Web SDK的这一阶段,您不需要XDM架构。 相反,您可以填充
data
对象,这会将数据直接发送到Adobe Analytics。 迁移到Web SDK完成后,您可以为组织创建架构,并使用数据流映射填充适用的XDM字段。 如果在迁移过程的此阶段需要架构,则贵组织将被强制使用Adobe Analytics XDM架构。 使用此架构会使贵组织将来更难以使用自己的架构。
- 实施更改需要开发人员干预:如果要更改Web SDK实施,必须与开发团队合作来编辑网站上的代码。 迁移到Web SDK标记扩展的方法可避免此缺点。
- 实施技术债务:由于此方法使用现有实施的修改形式,因此将来需要跟踪实施逻辑和执行更改会更加困难。
- 需要映射才能将数据发送到Platform:当您的组织准备好使用Customer Journey Analytics时,您必须将数据发送到Adobe Experience Platform中的数据集。 此操作要求
data
对象中的每个字段都必须是数据流映射工具中的条目,以便将其分配给XDM架构字段。 此工作流的映射只需执行一次,并且不涉及对实施进行更改。 但是,这是一个额外的步骤,在XDM对象中发送数据时不需要执行此步骤。
Adobe建议在以下情况下遵循此实施路径:
- 您已有使用Adobe AnalyticsAppMeasurementJavaScript库的实施。 如果您的实施使用Adobe Analytics标记扩展,请改为遵循从Adobe Analytics标记扩展迁移到Web SDK标记扩展。
- 您打算在将来使用Customer Journey Analytics,但不希望从头开始使用Web SDK实施来替换Analytics实施。 在Web SDK上从头开始替代实施需要做出最大努力,但同时需要提供最可行的长期实施架构。 如果贵组织愿意进行干净的Web SDK实施,请参阅Customer Journey Analytics用户指南中的通过Adobe Experience Platform Web SDK摄取数据。
迁移到Web SDK所需的步骤
以下步骤包含要努力实现的具体目标。 单击每个步骤以了解完成该操作的详细说明。
在Adobe Experience Platform数据收集中创建数据流。 当您将数据发送到此数据流时,它会将数据转发到Adobe Analytics。 将来,同一数据流会将数据转发到Customer Journey Analytics。
- 导航到experience.adobe.com并使用您的凭据登录。
- 使用右上角的主页或产品选择器导航到 数据收集。
- 在左侧导航中,选择 数据流。
- 选择 新数据流。
- 输入所需的名称,然后选择 保存。
- 创建数据流后,选择 添加服务。
- 在服务下拉菜单中,选择 Adobe Analytics。
- 输入与您当前将分析数据发送到的网站相同的报表包ID。 单击 保存。
您的数据流现在可以接收数据并传递给Adobe Analytics。 请记下数据流ID,因为在代码中配置Web SDK时需要此ID。
alloy.js
的最新版本,以便使用其方法调用。 有关详细信息和要使用的代码块,请参阅使用JavaScript库安装Web SDK。使用Web SDK configure
命令将您的实施设置为指向在上一步中创建的数据流。 必须在每个页面上设置configure
命令,以便您可以将其与库安装代码一起包含。
在Web SDK configure
命令中使用datastreamId
和orgId
属性:
- 将
datastreamId
设置为从上一步检索到的数据流ID。 - 将
orgId
设置为您组织的IMS组织。
code language-js |
---|
|
您可以选择在configure
命令中设置其他属性,具体取决于贵组织的实施要求。
更改您的Analytics实施,使其不依赖于AppMeasurement.js
或s
对象。 相反,应将变量设置为格式正确的JavaScript对象,该对象在发送到Adobe时会被转换为JSON对象。 在网站上设置数据层在设置值时非常有用,因为您可以继续引用这些相同的值。
若要将数据发送到Adobe Analytics,Web SDK有效负载必须将data.__adobe.analytics
与此对象中设置的所有Analytics变量一起使用。 此对象中的变量与其对应的AppMeasurement变量具有相同的名称和格式。 例如,如果设置products
变量,请勿像使用XDM时那样将其拆分为单独的对象。 相反,如果设置s.products
变量,请完全将其作为字符串包含:
code language-json |
---|
|
最终,此有效负载包含所有所需的值,并且实施中对s
对象的所有引用都将被删除。 您可以使用JavaScript提供的任何资源来设置此有效负载对象,包括点表示法来设置各个值。
code language-js |
---|
|
更新调用s.t()
和s.tl()
的所有实例,将它们替换为sendEvent
命令。 需要考虑三种情况:
-
页面查看跟踪:将页面查看跟踪调用替换为Web SDK
sendEvent
命令:code language-js // If your current implementation has this line of code: s.t(); // Replace it with this line of code. The dataObj object contains the variables to send. alloy("sendEvent", dataObj);
-
自动链接跟踪:默认情况下启用
clickCollectionEnabled
配置属性。 它会自动设置正确的链接跟踪变量,以将数据发送到Adobe Analytics。 如果要禁用自动链接跟踪,请在configure
命令中将此属性设置为false
。 -
手动链接跟踪: Web SDK在pageview调用与非页面视图调用之间没有单独的命令。 在有效负荷对象中提供该区别。
code language-js // If your current implementation has this line of code: s.tl(true,"o","Example custom link"); // Replace it with these lines of code. Add the required fields to the dataObj object. dataObj.data.__adobe.analytics.linkName = "Example custom link"; dataObj.data.__adobe.analytics.linkType = "o"; dataObj.data.__adobe.analytics.linkURL = "https://example.com"; alloy("sendEvent", dataObj);
删除对AppMeasurement和s
对象的所有引用后,将更改发布到开发环境以验证新实施是否有效。 在验证所有组件均可正确工作后,您可以将更新发布到生产环境。
如果迁移正确,则您的网站上不再需要AppMeasurement.js
,并且可以删除对此脚本的所有引用。
此时,您的Analytics实施已完全放在Web SDK上,并准备好将来迁移到Customer Journey Analytics。