在 AMP 中对电子邮件请求进行身份验证

动态个性化电子邮件内容通常需要对用户进行身份验证。不过,为了保护用户数据,Gmail 中的 AMP 电子邮件内发出的所有 HTTP 请求都会被代理并删除 Cookie。

若要对来自 AMP 电子邮件的请求进行身份验证,您可以使用访问令牌

访问令牌

您可以使用访问令牌对用户进行身份验证。访问令牌由电子邮件发件人提供并检查。发件人使用令牌来确保只有有权访问 AMP 电子邮件的用户才能发出电子邮件中包含的请求。访问令牌必须具有加密安全、时间和范围限制。它们包含在请求的网址中。

以下示例演示了如何使用 <amp-list> 显示经过身份验证的数据:

<amp-list src="https://example.com/endpoint?token=REPLACE_WITH_YOUR_ACCESS_TOKEN"
  height="300">
  <template type="amp-mustache">
    ...
  </template>
</amp-list>

同样,在使用 <amp-form> 时,请将访问令牌放在 action-xhr 网址中。

<form action-xhr="https://example.com/endpoint?token=REPLACE_WITH_YOUR_ACCESS_TOKEN" method="post">
  <input type="text" name="data">
  <input type="submit" value="Send">
</form>

示例

以下示例考虑了一项假设的记事服务,该服务允许已登录的用户向其帐号添加备注并在以后查看。该服务想要向用户 jane@example.com 发送一封电子邮件,其中包含他们之前记下的记事列表。当前用户的备注列表可通过端点 https://example.com/personal-notes 获取(采用 JSON 格式)。

在发送电子邮件之前,该服务会为 jane@example.com: A3a4roX9x 生成一个加密安全的限定使用访问令牌。访问令牌包含在网址查询内的字段名称 exampletoken 中:

<amp-list src="https://example.com/personal-notes?exampletoken=A3a4roX9x" height="300">
  <template type="amp-mustache">
    <p>{{note}}</p>
  </template>
</amp-list>

端点 https://example.com/personal-notes 负责验证 exampletoken 参数并查找与令牌关联的用户。

如需了解详情,请参阅使用受限的访问令牌