Google 标签管理器不会将事件推送到 Android 上的数据层

Google tag manager won't push event's to datalayer on Android

我正在尝试在 this guide 之后的 Android 应用程序中实施跟踪代码管理器,但由于某些原因我无法将事件推送到数据层。

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    TagManager tagManager = TagManager.getInstance(getApplicationContext());
    TagManager.getInstance(getApplicationContext()).setVerboseLoggingEnabled(true);

    PendingResult<ContainerHolder> pending = tagManager.loadContainerPreferFresh(GOOGLE_TAG_MANAGER_CONTAINER_ID, R.raw.gtm_default_container_v2);
    pending.setResultCallback(new ResultCallback<ContainerHolder>() {
        @Override
        public void onResult(ContainerHolder containerHolder) {
            TagManager.getInstance(getApplicationContext()).getDataLayer().push("event", "screenName");
            // Using the "pushEvent" method doesn't work either
            // TagManager.getInstance(getApplicationContext()).getDataLayer().pushEvent("screenName", DataLayer.mapOf());
        }
    }, 2, TimeUnit.SECONDS);
}

当我尝试 运行 我的应用程序时,我的所有日​​志都是这样说的

V/GoogleTagManager﹕ Attempting to load a container from the resource ID 2131099649 (com.example.cpe.gatestapp:raw/gtm_default_container_v2)
V/GoogleTagManager﹕ Deleted 0 expired items
W/GoogleTagManager﹕ Failed to extract the container from the resource file. Resource is a UTF-8 encoded string but doesn't contain a JSON container
V/GoogleTagManager﹕ The container was successfully loaded from the resource (using binary file)
E/GoogleTagManager﹕ Invalid macro: _gtm.loadEventEnabled
V/GoogleTagManager﹕ Attempting to load resource from disk
V/GoogleTagManager﹕ loadAfterDelay: containerId=GTM-XXXXXX delay=0
D/GoogleTagManager﹕ Setting previous container version: MQ[=13=]
E/GoogleTagManager﹕ Invalid macro: _gtm.loadEventEnabled
V/GoogleTagManager﹕ The Disk resource was successfully read.
V/GoogleTagManager﹕ Start loading resource from network ...
V/GoogleTagManager﹕ Successfully loaded supplemented resource: zzi_p: "MQ[=13=]"
V/GoogleTagManager﹕ No change for container: GTM-XXXXXX
V/GoogleTagManager﹕ loadAfterDelay: containerId=GTM-XXXXXX delay=43200000
D/GoogleTagManager﹕ Setting previous container version: MQ[=13=]
E/GoogleTagManager﹕ Invalid macro: _gtm.loadEventEnabled
V/GoogleTagManager﹕ setting refresh time to current time: 1435818825632
V/GoogleTagManager﹕ Load resource from network finished.

来自我的 GA 和跟踪代码管理器帐户的屏幕截图:

我想通了,我的问题的答案很简单。

所以我创建了一个 Analytics Tracker,用于跟踪我的应用程序是否崩溃。我做了一个选择,如果我 运行 我的应用程序处于调试模式,也就是来自 AndroidStudio 的 运行,我的 Tracker 将生成一个 'dryRun'。

所以我认为 TagManager 正在使用 Analytics 跟踪器发送所有事件。这就是为什么它有助于禁用我的 GoogleAnalytics 跟踪器上的 dryRun。