1

amp-analytics在 AMP 页面中使用该组件来跟踪页面浏览量。我的请求源(将数据发送到的端点)包括一个正斜杠,如下所示:

request.source.com/endpoint

AMP 不喜欢这样并给出以下错误:

amp-analytics request source must start with "https://" or "//" or be relative and served from either https or from localhost. Invalid value:

https://request.source.com%2Fendpoint/i?url=http%3A%2F%2Fcontent.url.com%3A8079%2Fregular-html-version.html&page=Sample%20document&res=2560x1440&stm=1538590011734&tz=240&aid=25&p=web&tv=amp-0.2&cd=24&cs=UTF-8&duid=amp-CGG5vSIemmau7QUKCzi1yw&lang=en-us&refr=&stm=240&vp=452x1270&e=pv

请注意,它将正斜杠 URL 编码为%2F. 我还尝试在脚本中对其进行编码。这没什么区别。

另请注意,当我从请求源中删除正斜杠(即仅使用request.source.com)时,它可以正常工作。(但产品要求端点包含该正斜杠)。

关于如何实现这一目标的任何想法?这是我的 AMP 代码:

<script async custom-element="amp-analytics" src="https://cdn.ampproject.org/v0/amp-analytics-0.1.js"></script>
<amp-analytics type="snowplow" id="snowplow1">
    <script type="application/json">
        {
            "vars": {
                "collectorHost": "request.source.com/endpoint",
                "appId": "25"
            },
            "triggers": {
                "trackPageview": {
                    "on": "visible",
                    "request": "pageView"
                }
            }
        }
    </script>
</amp-analytics>
4

1 回答 1

1

您看到这个的原因是变量是 url 编码的。

您需要创建自定义的,而不是使用 amp-analytics 中的默认扫雪机实现。复制此配置:https ://github.com/ampproject/amphtml/blob/0a84124122b516d33e8f815c4d7205ea92f0865b/extensions/amp-analytics/0.1/vendors/snowplow.js

然后使用此文档在配置对象中添加您的“端点”:https ://github.com/ampproject/amphtml/blob/0a84124122b516d33e8f815c4d7205ea92f0865b/extensions/amp-analytics/amp-analytics.md#specifying-configuration-data

你最终会在你的 json 配置中得到这样的东西:

...
'basePrefix': 'https://${collectorHost}/endpoint/i?url=${canonicalUrl}&page=${title}&' +
...
于 2018-10-03T19:30:04.163 回答