重定向使用 Microsoft Entra 应用程序代理发布的应用的硬编码链接

Microsoft Entra 应用程序代理支持用户远程或在其自己的设备上使用本地应用。 但是,某些应用已通过嵌入到 HTML 中的本地链接开发。 远程使用应用时,这些链接将无法正常跳转。 如果有多个指向彼此的本地应用程序,你的用户会需要这些链接在他们不在办公室时能继续正常使用。

确保链接在企业网络内部和外部都能够正常工作的最佳方式是,将应用的外部 URL 与其内部 URL 配置为相同的。 使用自定义域来配置你的外部 URL,以获取企业域名,而不是默认的应用程序代理域。

如果无法在租户中使用自定义域,还有其他几个选项可提供此功能。 所有其他选项也都与自定义域兼容且彼此兼容,因此可以配置自定义域和其他解决方案。

注意

通过 JavaScript 生成的硬编码内部 URL 不支持链接转换。

选项 1:使用 Microsoft Edge - 此解决方案仅适用于你计划建议或要求用户通过 Microsoft Edge 浏览器访问应用程序的情况。 它处理所有已发布的 URL。

选项 2:使用 MyApps 扩展 - 此解决方案要求用户安装客户端浏览器扩展,但它会处理所有已发布的 URL,并可与大多数热门浏览器一起使用。

选项 3:使用链接转换设置 - 这是一种管理端设置选项,对用户不可见。 但是,它只会处理 HTML 和 CSS 中的 URL。

无论用户位于何处,这三个功能都可使链接保持正常工作。 如果具有直接指向内部终结点或端口的应用,可以将这些内部 URL 映射到已发布的外部应用程序代理 URL 中。

注意

最后一个选项只适用于出于任何原因无法使用自定义域来使其应用具有相同的内部和外部 URL 的租户。 启用此功能之前,请查看 Microsoft Entra 应用程序代理中的自定义域是否适用于你。

或者,如果需要配置链接转换的应用程序是 SharePoint,请参阅配置 SharePoint 2013 的备用访问映射,以获取映射链接的另一种方法。

选项 1:Microsoft Edge 集成

可以使用 Microsoft Edge 进一步保护应用程序和内容。 若要使用此解决方案,需要求/建议用户通过 Microsoft Edge 访问应用程序。 使用应用程序代理发布的所有内部 URL 都会被 Microsoft Edge 识别并重定向到相应的外部 URL。 重定向可确保硬编码的内部 URL 正常工作。 如果用户在浏览器中直接键入该内部 URL,即使该用户是远程用户,该 URL 也可正常运行。

若要了解详细信息(包括如何配置此选项),请参阅在 Microsoft Intune 中使用适用于 iOS 和 Android 的 Microsoft Edge 管理 Web 访问文档。

选项 2:MyApps 浏览器扩展

通过 MyApps 浏览器扩展,随应用程序代理一起发布的所有内部 URL 都将识别扩展并重定向到相应的外部 URL。 重定向可确保所有硬编码的内部 URL 都正常工作。 如果用户在浏览器地址栏中直接键入该内部 URL,即使该用户是远程用户,该 URL 也可正常运行。

若要使用此功能,用户需要下载该扩展并登录。 管理员或用户不需要进行其他配置。

若要了解详细信息(包括如何配置此选项),请参阅 MyApps 浏览器扩展文档。

注意

MyApps 浏览器扩展不支持通配符 URL 的链接转换。

应用程序代理服务通过 HTML 和 CSS 搜索发布的内部链接,并在启用链接转换时对它们进行转换。 链接转换提供不间断的体验。 使用 MyApps 浏览器扩展优先于链接转换设置,因为它可以提供更高性能的体验。

注意

如果使用的是选项 2 或选项 3,则一次只应启用其中之一。

进行身份验证后,当代理服务器将应用程序数据传递给用户时,应用程序代理会扫描应用程序以获取硬编码的链接,并将其替换为各自的已发布外部 URL。

应用程序代理假定应用程序采用 UTF-8 编码。 如果不是这种情况,则在 HTTP 响应头中指定编码类型(如 Content-Type:text/html;charset=utf-8)。

链接转换功能仅查找位于应用正文的代码标记中的链接。 应用程序代理具有一个单独的功能,用于转换标头中的 Cookie 或 URL。

本地应用程序中有两种常见类型的内部链接:

  • 相对内部链接,可指向本地文件结构(如 /claims/claims.html)中的共享资源。 这些链接在通过应用程序代理发布的应用中自动运行,并且在有无链接转换时均能继续运行。
  • 指向其他本地应用(如 http://expenses)或已发布文件(如 http://expenses/logo.jpg)的硬编码内部链接。 链接转换功能会对硬编码的内部链接进行操作,将其更改为指向远程用户需要访问的外部 URL。

应用程序代理支持对其进行链接转换且存在于 HTML 代码标记中的属性的完整列表包括:

  • a (href)
  • audio (src)
  • base (href)
  • button (formaction)
  • div (data-background, style, data-src)
  • embed (src)
  • form (action)
  • frame (src)
  • head (profile)
  • html (manifest)
  • iframe (longdesc, src)
  • img (longdesc, src)
  • input (formaction, src, value)
  • link (href)
  • menuitem (icon)
  • meta (content)
  • object (archive, data, codebase)
  • script (src)
  • source (src)
  • track (src)
  • video (src, poster)

此外,在 CSS 中,URL 属性也会被转换。

链接转换对每个应用程序均启用,以便可以按应用级别控制用户体验。 如果要将该应用的链接,而不是指向该应用的链接进行转换,请启用应用的链接转换功能。

例如,假设有三个通过应用程序代理发布的应用程序,这些应用程序均彼此链接:Benefits、Expenses 和 Travel。 还有第四个应用,Feedback,但它不是通过应用程序代理发布的。

如果启用 Benefits 应用的链接转换,Expenses 和 Travel 的链接将重定向到这些应用的外部 URL。 但不会重定向 Feedback 的链接,因为没有任何外部 URL。 由于这两个应用尚未启用链接转换,因此从 Expenses 和 Travel 转回 Benefits 的链接不起作用。

Links from Benefits to other apps when link translation is enabled

为了提高性能和安全性,不会转换某些链接:

  • 代码标记外的链接。
  • 不在 HTML 或 CSS 中的链接。
  • URL 编码格式中的链接。
  • 从其他程序打开的内部链接。 不会转换通过电子邮件或即时消息发送或其他文档中包含的链接。 用户需要了解转到外部 URL。

如果需要支持这两个方案之一,请使用相同的内部和外部 URL,而不是链接转换。

链接转换入门就像单击按钮一样简单:

  1. 至少以应用程序管理员的身份登录到 Microsoft Entra 管理中心

  2. 浏览到“标识”>“应用程序”>“企业应用程序”>“所有应用程序”。

  3. 选择要管理的应用。

  4. 将“转换应用程序主体中的 URL”改为“是”。

    Select Yes to translate URLs in application body

  5. 单击“保存”应用所做的更改。

现在,当用户访问此应用程序时,代理将扫描租户上通过应用程序代理发布的内部 URL。

后续步骤