reCAPTCHA Enterprise for WAF 与 Google Cloud Armor 集成的功能

reCAPTCHA Enterprise for WAF 与 Google Cloud Armor 集成具有以下功能:reCAPTCHA 验证页面reCAPTCHA 操作令牌reCAPTCHA 会话令牌。本文档可帮助您了解这些功能,并确定哪种功能最适合您的用例。

功能比较

下表简要展示了 reCAPTCHA 质询页面、reCAPTCHA 操作令牌和 reCAPTCHA 会话令牌:

比较类别 reCAPTCHA 质询页面 reCAPTCHA 操作令牌 reCAPTCHA 会话令牌
用例 如果您怀疑有垃圾邮件活动定向到您的网站,而您需要筛掉机器人,请使用 reCAPTCHA 质询页面。

此方法会中断用户的活动,因为用户必须验证人机识别系统质询。

使用 reCAPTCHA 操作令牌保护用户操作。 使用 reCAPTCHA 会话令牌来保护网站网域上的整个用户会话。
集成类型

集成时,您需要配置 Google Cloud Armor 安全政策规则。

集成时,您需要执行以下操作:

  • 在网站的各个页面上安装 reCAPTCHA JavaScript。
  • 将操作令牌附加到各个请求标头中。
  • 配置 Google Cloud Armor 安全政策规则。

集成时,您需要执行以下操作:

  • 在网站的每个网页上安装 reCAPTCHA JavaScript。
  • 配置 Google Cloud Armor 安全政策规则。
检测准确率

此过程涉及重定向至 reCAPTCHA 质询页面,该页面可能不会收到所有页面专属信号。因此,机器人检测可能会不太准确。

最高

操作令牌保护用户操作。

会话令牌可保护网站网域上的整个用户会话。

支持的 reCAPTCHA 版本 reCAPTCHA 验证页面使用经过优化的 reCAPTCHA 版本,以最大程度减少集成量。 reCAPTCHA Enterprise 基于得分和复选框的网站密钥 reCAPTCHA Enterprise 基于得分的网站密钥

reCAPTCHA 质询页面

您可以使用 reCAPTCHA 质询页面功能将传入的请求重定向到 reCAPTCHA Enterprise,以确定每个请求是否可能具有欺诈或合法性。

这种重定向应用和可能的人机识别系统质询会中断用户的活动。如果您怀疑存在指向您网站的垃圾邮件活动,我们建议您将其用于筛掉机器人。

当最终用户首次访问您的网站时,会发生以下事件:

  1. 用户的请求会在 WAF 层重定向到 reCAPTCHA Enterprise。
  2. reCAPTCHA Enterprise 会返回嵌入到 reCAPTCHA JavaScript 中的 HTML 页面。
  3. 呈现页面后,reCAPTCHA Enterprise 会评估用户互动。如有必要,reCAPTCHA Enterprise 向用户提供人机识别系统质询。
  4. 根据评估结果,reCAPTCHA Enterprise 会执行以下操作:

    1. 如果用户互动通过评估,reCAPTCHA Enterprise 会发出豁免 Cookie。浏览器会将此豁免 Cookie 附加到用户之后针对同一网站发出的请求,直到该 Cookie 过期为止。默认情况下,豁免 Cookie 会在 3 小时后过期。
    2. 如果用户互动未通过评估,reCAPTCHA Enterprise 不会发出豁免 Cookie。
  5. 如果用户使用 GET/HEAD 调用访问网页,reCAPTCHA Enterprise 会使用豁免 Cookie 重新加载网页。如果用户使用 POST/PUT 调用访问网页,则用户需要点击页面上的“重新加载”链接。

  6. Google Cloud Armor 会豁免具有有效例外 Cookie 的请求,不再重定向请求,并授予对您网站的访问权限。

以下序列图显示了 reCAPTCHA 质询页面工作流程:

reCAPTCHA 操作令牌

您可以使用 reCAPTCHA 操作令牌来保护重要的用户互动(例如结账)。

在此功能中,您将在网页上安装 reCAPTCHA Enterprise 网站密钥。如果存在用户互动,reCAPTCHA Enterprise 会向最终用户的浏览器发送加密响应(称为操作令牌)。您需要将此操作令牌附加到预定义的请求标头中,以保护任何用户操作。Google Cloud Armor 会解码并验证操作令牌特性,而不是后端应用。您可以根据操作令牌中的各种特性配置安全政策规则,而无需从后端应用评估令牌。

以下序列图显示了 reCAPTCHA 操作令牌工作流程:

reCAPTCHA 操作令牌特性

下表列出了 reCAPTCHA 操作令牌的特性集:

特性名称 数据类型 说明
score float reCAPTCHA 令牌的得分。有效得分的范围为 0.0 到 1.0。1.0 分表示互动风险低,很可能是合法的,0.0 表示互动风险高,可能具有欺诈性。如需了解详情,请参阅解读得分
captcha_status 字符串 reCAPTCHA 令牌中的人机识别系统状态。以下是三种可能的状态:
  • 评估用户时未涉及质询。
  • 涉及了质询,用户采用了正确的解决方法。
  • 涉及了质询,用户未能解决这些问题。
action_name 字符串 action_name 是您在调用 grecaptcha.enterprise.execute() 时为用户交互指定的操作参数。如需了解详情,请参阅操作名称

reCAPTCHA 会话令牌

如果要保护网站网域上的整个用户会话,您可以使用 reCAPTCHA 会话令牌。会话令牌允许您在指定时间段内重复使用现有的 reCAPTCHA Enterprise 评估,因此不需要为特定用户进行进一步评估,从而减少 reCAPTCHA Enterprise 的负载。

在此功能中,reCAPTCHA JavaScript 会在评估后在最终用户的浏览器上将会话令牌设置为 Cookie。只要 reCAPTCHA JavaScript 保持活跃状态,最终用户的浏览器就会附加 Cookie 并刷新 Cookie。Google Cloud Armor 会根据安全政策规则验证此 Cookie 并应用操作。

为了使 reCAPTCHA Enterprise 了解最终用户的浏览模式,我们建议您在网站的所有网页上使用 reCAPTCHA 会话令牌。

以下序列图显示了 reCAPTCHA 会话令牌工作流:

reCAPTCHA 会话令牌特性

下表列出了 reCAPTCHA 会话令牌的特性:

特性名称 数据类型 说明
Score float reCAPTCHA 令牌的得分。有效得分的范围为 0.0 到 1.0。1.0 分表示互动风险低,很可能是合法的,0.0 表示互动风险高,可能具有欺诈性。如需了解详情,请参阅解读得分

后续步骤

  • 了解如何实现 reCAPTCHA Enterprise for WAF 与 Google Cloud Armor 集成的功能