封装的令牌支持

简介

默认情况下,AEM使用令牌身份验证处理程序来验证每个请求。 但是,为了提供身份验证请求,令牌身份验证处理程序需要访问每个请求的存储库。 之所以出现这种情况,是因为使用Cookie维护身份验证状态。 从逻辑上讲,需要在存储库中保留状态以验证后续请求。 实际上,这意味着身份验证机制是有状态的。

这对于横向扩展性来说尤为重要。 在多实例设置中(如下面所示的发布场),无法以最佳方式实现负载平衡。 通过有状态身份验证,持久身份验证状态将仅在用户首次进行身份验证的实例上可用。

chlimage_1-33

以下方案为例:

用户可能在发布实例1上进行了身份验证,但如果后续请求转到发布实例2,则该实例没有持久的身份验证状态,因为该状态会保留在发布实例1的存储库中,而发布实例2具有其自己的存储库。

解决方案是在负载平衡器级别配置置顶连接。 通过粘性连接,用户将始终定向到同一发布实例。 因此,无法真正地实现最佳负载平衡。

如果发布实例不可用,则在该实例上经过身份验证的所有用户都将丢失其会话。 这是因为验证身份验证Cookie需要存储库访问。

使用封装的令牌进行无状态身份验证

水平可扩展性解决方案是使用AEM中新的封装令牌支持进行无状态身份验证。

封装令牌是一段密码学,它允许AEM在脱机时安全地创建和验证身份验证信息,而无需访问存储库。 这样,就可以在所有发布实例上发生身份验证请求,而无需粘性连接。 它还具有提高身份验证性能的优势,因为无需为每个身份验证请求访问存储库。

您可以在下面的MongoMK作者和TarMK发布实例中,了解在地理上分散的部署中这项功能的工作原理:

chlimage_1-34

注意

请注意,封装令牌与身份验证有关。 它可确保无需访问存储库即可验证Cookie。 但是,仍然需要用户存在于所有实例上,并且每个实例都可以访问存储在该用户下的信息。

例如,如果由于封装令牌的工作方式而在发布实例号1上创建了新用户,则该用户将在发布实例号2上成功进行身份验证。 如果用户在第二个发布实例上不存在,则请求仍将不成功。

配置封装令牌

注意

只有符合以下条件时,所有可同步用户并依赖令牌身份验证(如SAML和OAuth)的身份验证处理程序才能与封装的令牌一起使用:

  • 会话会置顶,或

  • 同步开始时,已在AEM中创建用户。 这意味着在同步过程中,如果处理程序​创建​用户,将不支持封装的令牌。

在配置封装令牌时,您需要考虑以下几项:

  1. 由于涉及的密码学,所有实例都需要具有相同的HMAC密钥。 自AEM 6.3起,关键材料不再存储在存储库中,而是存储在实际的文件系统中。 考虑到这一点,复制密钥的最佳方法是将它们从源实例的文件系统复制到要将密钥复制到的目标实例的文件系统。 请参阅下面“复制HMAC密钥”下的更多信息。
  2. 需要启用封装令牌。 这可以通过Web控制台来完成。

复制HMAC密钥

HMAC密钥以/etc/key的二进制属性形式存在于存储库中。 您可以通过按其旁边的​view​链接来单独下载它:

chlimage_1-35

要跨实例复制密钥,您需要:

  1. 访问包含要复制的关键材料的AEM实例,通常是创作实例;

  2. 在本地文件系统中找到com.adobe.granite.crypto.file包。 例如,在以下路径下:

    • <author-aem-install-dir>/crx-quickstart/launchpad/felix/bundle21

    每个文件夹内的bundle.info文件将标识包名称。

  3. 导航到数据文件夹。 例如:

    • <author-aem-install-dir>/crx-quickstart/launchpad/felix/bundle21/data
  4. 复制HMAC和主控文件。

  5. 然后,转到要将HMAC密钥复制到的目标实例,然后导航到数据文件夹。 例如:

    • <publish-aem-install-dir>/crx-quickstart/launchpad/felix/bundle21/data
  6. 粘贴您之前复制的两个文件。

  7. 如果目标实 例已在运行,请刷新Crypto Bundle。

  8. 对要将密钥复制到的所有实例重复上述步骤。

启用封装令牌

复制HMAC密钥后,您可以通过Web控制台启用封装令牌:

  1. 将浏览器指向https://serveraddress:port/system/console/configMgr
  2. 查找名为​Day CRX令牌身份验证处理程序​的条目,然后单击该条目。
  3. 在以下窗口中,勾选​启用封装的令牌支持​框,然后按​Save

在此页面上