使用 Microsoft Entra 应用程序代理为远程用户发布本地应用
Microsoft Entra 应用程序代理提供对本地 Web 应用程序的安全远程访问。 单一登录到 Microsoft Entra ID 后,用户可以通过外部 URL 或内部应用程序门户访问云端和本地的应用程序。 例如,应用程序代理可以为远程桌面、SharePoint、Teams、Tableau、Qlik 和业务线 (LOB) 应用程序提供远程访问和单一登录功能。
Microsoft Entra 应用程序代理是:
简单易用。 用户可像访问 Microsoft 365 以及其他与 Microsoft Entra ID 集成的 SaaS 应用一样访问你的本地应用程序。 无需更改或更新应用程序即可使用应用程序代理。
安全。 本地应用程序可以使用 Azure 的授权控制和安全分析功能。 例如,本地应用程序可使用条件访问和双重验证。 应用程序代理不要求通过防火墙打开入站连接。
经济高效。 本地解决方案通常需要设置和维护隔离区 (DMZ)、边缘服务器或其他复杂的基础结构。 应用程序代理在云中运行,易于使用。 若要使用应用程序代理,无需更改网络基础结构或在本地环境中安装其他设备。
提示
如果你已有 Microsoft Entra ID,可以利用它作为控制平面,来实现对本地应用程序的无缝安全访问。
以下列表并不详尽,但演示了在混合共存方案中使用应用程序代理的示例:
- 在不使用外围网络的情况下以简化的方式在外部发布本地 Web 应用
- 支持在云中和本地跨设备、资源与应用进行单一登录 (SSO)
- 支持对云中和本地的应用执行多重身份验证
- 快速利用 Microsoft 云安全性的云功能
- 集中管理用户帐户
- 集中控制标识和安全性
- 基于组成员身份自动添加或删除用户对应用程序的访问权限
本文将会说明 Microsoft Entra ID 和应用程序代理如何为远程用户提供单一登录 (SSO) 体验。 用户在不使用 VPN 或双重宿主服务器和防火墙规则的情况下安全连接到本地应用。 本文可帮助你了解应用程序代理如何将云的功能和安全优势引入本地 Web 应用程序。 此外,还会介绍可行的体系结构和拓扑。
提示
应用程序代理包括在云中运行的应用程序代理服务和在本地服务器上运行的专用网络连接器。 Microsoft Entra ID、应用程序代理服务和专用网络连接器协同工作,将用户登录令牌从 Microsoft Entra ID 安全地传递到 Web 应用程序。
应用程序代理适用于:
- 使用集成 Windows 身份验证进行身份验证的 Web 应用程序
- 使用基于窗体或基于标头的访问的 Web 应用程序
- 想要公开给不同设备上丰富应用程序的 Web API
- 托管在远程桌面网关后面的应用程序
- 与 Microsoft 身份验证库 (MSAL) 集成的丰富客户端应用
应用程序代理支持单一登录。 有关支持的方法的详细信息,请参阅选择单一登录方法。
过去的远程访问方式
以前,用于防范攻击者访问内部资源,同时方便远程用户进行访问的控制平面完全位于 DMZ(外围网络)中。 但是,部署在外围网络中的、由外部客户端用来访问企业资源的 VPN 和反向代理解决方案并不适合云世界。 它们往往存在以下弱点:
- 硬件成本
- 维护安全性(修补、监视端口等)
- 在边缘对用户进行身份验证
- 对访问外围网络中的 Web 服务器的用户进行身份验证
- 使用 VPN 客户端软件的分发和配置维护远程用户的 VPN 访问权限。 此外,需要在外围网络中维护已加入域的服务器,这很容易受到外部攻击。
在当今的云优先世界中,Microsoft Entra ID 最适合用于控制哪些人员和内容可以进入你的网络。 Microsoft Entra 应用程序代理与新式身份验证和基于云的技术(例如 SaaS 应用程序和标识提供者)集成。 用户可以借助这些集成从任意位置访问应用。 应用程序代理不仅更适合当今的数字工作区,而且比 VPN 和反向代理解决方案更安全,且更易于实施。 远程用户可像访问 Microsoft 以及其他与 Microsoft Entra ID 集成的 SaaS 应用一样访问你的本地应用程序。 无需更改或更新应用程序即可使用应用程序代理。 此外,应用程序代理不要求通过防火墙打开入站连接。 只需设置好应用程序代理,然后就可以忘记它。
远程访问的未来
在当今的数字工作区中,用户可在任意位置使用多种设备和应用完成工作。 唯一的定数就是用户标识。 正因如此,当今实现安全网络的第一步就是使用 Microsoft Entra 标识管理功能作为安全控制平面。 使用标识作为控制平面的模型通常包括以下组件:
- 一个用于跟踪用户和用户相关信息的标识提供者。
- 设备目录,用于维护有权访问企业资源的设备列表。 此目录包含相应的设备信息(例如设备类型、完整性等)。
- 策略评估服务,用于确定某个用户和设备是否符合安全管理员制定的策略。
- 授予或拒绝组织资源访问权限的功能。
Microsoft Entra ID 使用应用程序代理来跟踪需要访问本地发布的和云中的 Web 应用的用户。 它针对这些应用提供一个中心管理点。 尽管不一定要这样做,但我们建议同时启用 Microsoft Entra 条件访问。 在用户如何进行身份验证和获取访问权限方面定义条件,可以进一步确保只有适当的人员才能访问你的应用程序。
注意
必须知道,Microsoft Entra 应用程序代理旨在替代需要访问内部资源的漫游(或远程)用户所用的 VPN 或反向代理。 它并不适合企业网络中的内部用户。 内部用户不必要地使用应用程序代理可能会意外地造成不利的性能问题。
应用程序代理工作原理概述
下图显示了 Microsoft Entra ID 和应用程序代理如何共同向本地应用程序提供单一登录。
- 在用户通过终结点访问应用程序后,将用户定向到 Microsoft Entra 登录页。
- 成功登录后,Microsoft Entra ID 会向用户的客户端设备发送令牌。
- 客户端将令牌发送到应用程序代理服务。 该服务从令牌中检索用户主体名称 (UPN) 和安全主体名称 (SPN)。 然后,应用程序代理将请求发送到连接器。
- 连接器代表用户执行所需的单一登录 (SSO) 身份验证。
- 连接器将请求发送到本地应用程序。
- 通过连接器和应用程序代理服务将响应发送给用户。
注意
与大多数 Microsoft Entra 混合代理一样,专用网络连接器不要求你通过防火墙打开入站连接。 第 3 步中的用户流量在应用程序代理服务处终止。 专用网络连接器(驻留在专用网络中)负责其余的通信。
组件 | 说明 |
---|---|
终结点 | 终结点是 URL 或最终用户门户。 用户可通过访问外部 URL 访问位于你网络外部的应用程序。 网络内的用户可以通过 URL 或最终用户门户访问应用程序。 当用户转到其中一个终结点时,将在 Microsoft Entra ID 中进行身份验证,并通过连接器路由到本地应用程序。 |
Microsoft Entra ID | Microsoft Entra ID 使用存储在云端的租户目录执行身份验证。 |
应用程序代理服务 | 应用程序代理服务作为 Microsoft Entra ID 的一部分在云中运行。 它将登录令牌从用户传递到专用网络连接器。 应用程序代理在收到请求时转发所有可访问的标头,并根据其协议将标头设置为客户端 IP 地址。 如果传入代理的请求已有该标头,则将客户端 IP 地址添加到逗号分隔列表的末尾,该地址为标头的值。 |
专用网络连接器 | 连接器是可在网络内的 Windows Server 上运行的轻型代理。 连接器管理云端应用程序代理服务与本地应用程序之间的通信。 连接器仅使用出站连接,因此无需在面向 Internet 的网络中打开入站端口。 连接器是无状态的,可根据需要从云中提取信息。 有关连接器的详细信息(例如,它们如何均衡负载和执行身份验证),请参阅了解 Microsoft Entra 专用网络连接器。 |
Active Directory (AD) | Active Directory 在本地运行,对域帐户执行身份验证。 配置单一登录后,连接器会与 AD 通信以执行所需的任何额外身份验证。 |
本地应用程序 | 最后,用户便可以访问本地应用程序。 |
应用程序代理是你在 Microsoft Entra 管理中心配置的 Microsoft Entra 服务。 使用应用程序代理可以在 Azure 云中发布与组织中内部应用程序服务器 URL 连接的外部公共 HTTP/HTTPS URL 终结点。 可将这些本地 Web 应用与 Microsoft Entra ID 集成,以支持单一登录。 然后,用户可以像访问 Microsoft 365 和其他 SaaS 应用一样,访问本地 Web 应用。
此功能的组件包括应用程序代理服务(在云中运行)、专用网络连接器(在本地服务器上运行的轻型代理)和 Microsoft Entra ID(标识提供者)。 所有三个组件协同工作,为用户提供单一登录体验来访问本地 Web 应用程序。
用户通过身份验证后,外部用户可在其桌面或 iOS/MAC 设备上使用一个显示 URL 或我的应用访问本地 Web 应用程序。 例如,应用程序代理可为远程桌面、SharePoint 站点、Tableau、Qlik、Outlook Web 版和业务线 (LOB) 应用程序提供远程访问和单一登录功能。
身份验证
可通过多种方法配置应用程序以便进行单一登录,所选的方法取决于应用程序使用的身份验证。 应用程序代理支持以下类型的应用程序:
- Web 应用程序
- 想要公开给不同设备上丰富应用程序的 Web API
- 托管在远程桌面网关之后的应用程序
- 与 Microsoft 身份验证库 (MSAL) 集成的丰富客户端应用
应用程序代理适用于使用以下本机身份验证协议的应用:
- 集成 Windows 身份验证 (IWA)。 对于 IWA,专用网络连接器使用 Kerberos 约束委派 (KCD) 对 Kerberos 应用程序的用户进行身份验证。
应用程序代理还支持在第三方集成或特定的配置方案中使用以下身份验证协议:
- 基于标头的身份验证。 此登录方法使用名为 PingAccess 的第三方身份验证服务。当应用程序使用标头进行身份验证时会使用此方法。 在此方案中,身份验证由 PingAccess 处理。
- 基于表单或密码的身份验证。 使用此身份验证方法时,用户在首次访问应用程序时使用用户名和密码登录。 首次登录后,Microsoft Entra ID 会为应用程序提供用户名和密码。 在此方案中,身份验证由 Microsoft Entra ID 处理。
- SAML 身份验证。 使用 SAML 2.0 或 WS 联合身份验证协议的应用程序支持基于 SAML 的单一登录。 使用 SAML 单一登录时,Microsoft Entra 会通过用户的 Microsoft Entra 帐户向应用程序进行身份验证。
有关支持的方法的详细信息,请参阅选择单一登录方法。
安全优势
应用程序代理和 Microsoft Entra 提供的远程访问解决方案支持可供客户利用的多种安全优势,包括:
经过身份验证的访问。 应用程序代理最适合用于发布支持预身份验证的应用程序,以确保只能通过身份验证的连接访问网络。 对于使用预身份验证的已发布应用程序,如果无法提供有效的令牌,将不允许流量通过应用程序代理服务流向本地环境。 预身份验证的独特性质会阻止大量的针对性攻击,只有经过身份验证的标识才能访问后端应用程序。
条件访问。 在与网络建立连接之前应用更丰富的策略控制。 使用条件访问可以针对允许哪些流量访问后端应用程序来定义限制。 基于位置、身份验证强度和用户风险配置文件,创建限制登录的策略。 随着条件访问的不断演进,会添加更多的控制措施来提高安全性,例如与 Microsoft Defender for Cloud Apps 的集成。 借助 Defender for Cloud Apps 集成可为本地应用程序配置实时监视,这样就可以利用条件访问基于条件访问策略来实时监视和控制会话。
流量终止。 与后端服务器重建会话时,发往后端应用程序的所有流量将在云中的应用程序代理服务上终止。 此连接策略意味着不会公开后端服务器来定向 HTTP 流量。 由于防火墙未受到攻击,可以更好地防范这些流量受到有针对性的 DoS(拒绝服务)攻击。
所有访问都是出站的。 专用网络连接器仅使用通过端口 80 和 443 与云中应用程序代理服务建立的出站连接。 由于没有入站连接,因此不需要为传入的连接或外围网络中的组件打开防火墙端口。 所有连接都是通过安全通道建立的出站连接。
基于安全分析和机器学习 (ML) 的智能。 应用程序代理是 Microsoft Entra ID 的一部分,因此它可以利用 Microsoft Entra ID 标识保护(需要 Premium P2 许可)。 Microsoft Entra ID 标识保护将机器学习安全智能与来自 Microsoft 反数字犯罪部门和 Microsoft 安全响应中心的数据馈送结合起来,以主动识别遭到入侵的帐户。 “Microsoft Entra ID 保护”针对高风险登录提供实时防护。它考虑到多种因素,包括:从受感染的设备进行访问、通过匿名化网络进行访问,或者从异常位置和不太可能的位置进行访问。这样可以增强会话的风险配置文件。 此风险配置文件用于实时保护。 其中的许多报告与事件已通过某个 API 提供,便于与 SIEM 系统集成。
以服务的形式进行远程访问。 无需担心要维护和修补本地服务器即可启用远程访问。 应用程序代理是 Microsoft 拥有的一项 Internet 级服务,因此,用户始终可以获得最新的安全修补程序和升级。 未修补的软件仍会遭受大量攻击。 根据美国国土安全局的信息,高达 85% 的有针对性攻击都是可预防的。 使用此服务模型就不再需要承受管理边缘服务器的繁重负担,也不需要费力对其进行修补。
Intune 集成。 使用 Intune 可将企业流量与个人流量分开路由。 应用程序代理确保企业流量经过身份验证。 还可将应用程序代理和 Intune Managed Browser功能结合使用,使远程用户能够在 iOS 和 Android 设备上安全访问内部网站。
云路线图
实施应用程序代理的另一项主要优势是可将 Microsoft Entra ID 扩展到本地环境。 事实上,实施应用程序代理是将组织和应用转移到云的关键一步。 转移到云并摆脱本地身份验证可以减少本地的占用空间,并使用 Microsoft Entra 标识管理功能作为控制平面。 只需对现有应用程序做出极少量的更新甚至无需更新,就能访问单一登录、多重身份验证和集中管理等云功能。 将必要的组件轻松安装到应用程序代理即可建立远程访问框架。 转移到云后,可以访问最新的 Microsoft Entra 功能和更新,并可以访问高可用性和灾难恢复等功能。
若要详细了解如何将应用迁移到 Microsoft Entra ID,请参阅将应用程序迁移到 Microsoft Entra ID。
体系结构
示意图概括性地演示了 Microsoft Entra 身份验证服务和应用程序代理如何共同为用户提供本地应用程序的单一登录。
- 在用户通过终结点访问应用程序后,将其重定向到 Microsoft Entra 登录页面。 如果已配置条件访问策略,则此时会检查特定的条件,以确保符合组织的安全要求。
- 成功登录后,Microsoft Entra ID 向用户的客户端设备发送令牌。
- 客户端将令牌发送到应用程序代理服务,该服务检索令牌中的用户主体名称 (UPN) 和安全主体名称 (SPN)。
- 应用程序代理转发请求,专用网络连接器拾取请求。
- 连接器代表用户执行所需的任何其他身份验证(可选操作,是否执行将取决于身份验证方法),请求应用程序服务器的内部终结点,并将请求发送到本地应用程序。
- 通过连接器将应用程序服务器返回的响应发送到应用程序代理服务。
- 响应将从应用程序代理服务发送到用户。
Microsoft Entra 应用程序代理包括基于云的应用程序代理服务和本地连接器。 该连接器侦听来自应用程序代理服务的请求并处理与内部应用程序的连接。 必须注意,所有通信均通过 TLS 进行,始终从连接器发起,目标为应用程序代理服务。 也就是说,通信仅限出站。 连接器在执行所有调用时,都会使用客户端证书向应用程序代理服务进行身份验证。 只有在执行初始设置步骤时,连接安全性才有所不同,因为客户端证书是在此步骤中建立的。 有关更多详细信息,请参阅应用程序代理揭秘。
Microsoft Entra 专用网络连接器
应用程序代理使用 Microsoft Entra 专用网络连接器。 Microsoft Entra 专用访问使用相同的连接器。 若要详细了解连接器,请参阅 Microsoft Entra 专用网络连接器。
其他用例
到目前为止,本文只是重点介绍了如何使用应用程序代理在外部发布本地应用,同时允许对所有云应用和本地应用进行单一登录。 但是,应用程序代理还有其他值得探讨的用例。 其中包括:
- 安全发布 REST API。 在本地运行或者在云中的虚拟机上托管业务逻辑或 API 时,应用程序代理可提供一个公共终结点用于进行 API 访问。 使用 API 终结点访问可以控制身份验证和授权,而无需使用传入端口。 对于使用 Intune 的桌面、iOS、MAC 和 Android 设备,它可通过多重身份验证和基于设备的条件访问等 Microsoft Entra ID P1 或 P2 功能提供更高的安全性。 有关详细信息,请参阅如何让本机客户端应用程序与代理应用程序交互和结合 Microsoft Entra ID 和 API 管理使用 OAuth 2.0 保护 API。
- 远程桌面服务 (RDS)。 标准的 RDS 部署需要开放入站连接。 但是,使用应用程序代理的 RDS 部署会从运行连接器服务的服务器提供永久性的出站连接。 这样,你便可以通过远程桌面服务发布本地应用程序,为用户提供更多的应用程序。 此外,可以使用有限的一组双重验证方法和 RDS 的条件访问控制减小部署的受攻击面。
- 发布使用 WebSocket 进行连接的应用程序。 Qlik Sense 支持目前以公共预览版提供,今后将会扩展到其他应用。
- 让本机客户端应用程序与代理应用程序交互。 可使用 Microsoft Entra 应用程序代理来发布 Web 应用,它还可用于发布已使用 Microsoft 身份验证库 (MSAL) 配置的本机客户端应用程序。 本机客户端应用程序不同于 Web 应用,因为前者安装在设备上,而后者需通过浏览器进行访问。
结束语
我们的工作方式和所用的工具日新月异。 随着越来越多的员工自带设备办公并普遍使用软件即服务 (SaaS) 应用程序,组织管理和保护其数据的方式也必须有所革新。 公司不再只是在边界保护的自有围墙内部运营。 数据传输到的位置比以往任何时候更多 -- 它们会跨越本地和云环境。 这种演变已帮助提高用户的工作效率和协作能力,但同时也为保护敏感数据带来了更多的挑战。
不管你当前是在使用 Microsoft Entra ID 管理混合共存方案中的用户,还是对迁移到云的旅程感兴趣,实现 Microsoft Entra 应用程序代理都可以通过提供远程访问即服务来帮助减小本地空间占用量。
当今的组织应开始利用应用程序代理的以下优势:
- 在外部发布本地应用,消除维护传统 VPN 或其他本地 Web 发布解决方案和外围网络方法的相关开销
- 单一登录到所有应用程序,无论是 Microsoft 365 还是其他 SaaS 应用(包括本地应用程序)
- 云规模安全性,其中 Microsoft Entra 会利用 Microsoft 365 遥测来防止未经授权的访问
- Intune 集成可确保企业流量经过身份验证
- 集中管理用户帐户
- 自动更新可确保获得最新的安全修补程序
- 发布的新功能;SAML 单一登录支持的最新功能,以及应用程序 Cookie 的更精细管理