Rights Management Service 客户端部署说明

Rights Management 服务客户端(RMS 客户端)版本 2 也称为 MSIPC 客户端。 它是在 Windows 计算机上安装的软件,可用来与本地或云中的 Microsoft Rights Management 服务通信,以帮助保护对流经应用程序和设备的信息的访问和使用,无论这些信息是在组织边界的内部还是受管边界的外部。

RMS 客户端还可作为可选下载产品获取,在确认和接受其许可协议的情况下,客户可以通过第三方软件自由地分发它,使客户端能够保护和使用受 Rights Management Services 保护的内容。

重新分发 RMS 客户端

可以通过其他应用程序和 IT 解决方案自由地重新分发和捆绑 RMS 客户端。 如果你是应用程序开发人员或解决方案提供商,并想要重新分发 RMS 客户端,可以使用两个选项:

  • 建议:在应用程序安装过程中嵌入 RMS 客户端安装程序,然后在静默模式下运行(下一部分详述的 /quiet 开关)。

  • 使 RMS 客户端成为应用程序的必备组件。 如果采用此方法,则可能需要先向用户提供有关如何获取、安装以及更新计算机以使用该客户端的其他说明,然后用户才能使用你的应用程序。

安装 RMS 客户端

RMS 客户端包含在名为 setup_msipc_arch.exe 的安装程序可执行文件中,其中 arch> 为 x86(适用于 32 位客户端计算机)或 x64(适用于 64 位客户端计算机)。 64 位 (x64) 安装程序包既安装了 32 位运行时可执行文件(用于兼容在 64 位操作系统安装中运行的 32 位应用程序),也安装了 64 位运行时可执行文件(用于支持内置的 64 位应用程序)。 32 位 (x86) 安装程序不会在 64 位 Windows 安装上运行。

注意

若要安装 RMS 客户端,必须有提升的权限,例如,是本地计算机上管理员组的成员。

可以使用以下安装方法之一来安装 RMS 客户端:

  • 静默模式。 通过在命令行选项中使用 /quiet 开关,可以以静默方式在计算机上安装 RMS 客户端。 以下示例显示了 64 位客户端计算机上 RMS 客户端的静默模式安装:

    setup_msipc_x64.exe /quiet
    
  • 交互模式。 或者,也可以使用 RMS 客户端安装向导提供的基于 GUI 的安装程序来安装 RMS 客户端。 要以交互模式安装,请双击 RMS 客户端安装程序包 (setup_msipc_arch.exe),该包位于将其复制或下载到本地计算机上时所在的文件夹。

有关 RMS 客户端的问题和解答

以下部分包含有关 RMS 客户端的常见问题及其解答。

哪些操作系统支持 RMS 客户端?

Windows Server 2012及更高版本支持 RMS 客户端,以及Windows 8.1及更高版本。

哪些处理器或平台支持 RMS 客户端?

x86 和 x64 计算平台支持 RMS 客户端。

RMS 客户端安装在哪个位置?

默认情况下,RMS 客户端安装在 %ProgramFiles%\Active Directory Rights Management Services Client 2。<次版本号>。

与 RMS 客户端软件关联的文件有哪些?

以下文件将连同 RMS 客户端软件一起安装:

  • Msipc.dll

  • Ipcsecproc.dll

  • Ipcsecproc_ssp.dll

  • MSIPCEvents.man

除了上述文件外,RMS 客户端还将安装使用 44 种语言的多语言用户界面 (MUI) 支持文件。 若要验证支持的语言,请运行 RMS 客户端安装,然后在安装完成后,查看默认路径下的多语言支持文件夹中的内容。

在我安装受支持的操作系统时,是否默认包含 RMS 客户端?

不是。 此版本的 RMS 客户端作为可选下载产品交付,可单独安装在运行受支持 Microsoft Windows 操作系统版本的计算机上。

Microsoft Update 是否会自动更新 RMS 客户端?

如果此 RMS 客户端是使用静默安装选项安装的,则 RMS 客户端将继承当前的 Microsoft 更新设置。 如果 RMS 客户端是使用基于 GUI 的安装程序安装的,则 RMS 客户端安装向导会提示启用 Microsoft 更新。

RMS 客户端设置

以下部分包含有关 RMS 客户端的设置信息。 如果使用 RMS 客户端的应用程序或服务出现问题,这些信息可能很有帮助。

注意

某些设置取决于启用 RMS 的应用程序是作为客户端模式应用程序(如 Microsoft Word 和 Outlook,或使用 Windows 文件资源管理器的 Azure 信息保护客户端),还是作为服务器模式应用程序(如 SharePoint 和 Exchange)运行。 在下表中,这些设置分别标识为客户端模式服务器模式

RMS 客户端将许可证存储在客户端计算机上的哪个位置?

RMS 客户端将许可证存储在本地磁盘上,并在 Windows 注册表中缓存一些信息。

说明 客户端模式路径 服务器模式路径
许可证存储位置 %localappdata%\Microsoft\MSIPC %allusersprofile%\Microsoft\MSIPC\Server\SID>
模板存储位置 %localappdata%\Microsoft\MSIPC\Templates %allusersprofile%\Microsoft\MSIPC\Server\SID>
注册表位置 HKEY_CURRENT_USER
\Software
\Classes
\Local Settings
\Software
\Microsoft
\MSIPC
HKEY_CURRENT_USER
\Software
\Microsoft
\MSIPC
\Server
\<SID>\

注意

SID> 是运行服务器应用程序的帐户的安全标识符 (SID)。 例如,如果应用程序在内置的网络服务帐户下运行,则用该帐户的已知 SID 值 (S-1-5-20) 替换 SID>。

RMS 客户端的 Windows 注册表设置

你可以使用 Windows 注册表项设置或修改 RMS 客户端配置。 例如,作为已启用 RMS、要与 AD RMS 服务器通信的应用程序的管理员,你可能想要根据客户端计算机在 Active Directory 拓扑内的当前位置,更新企业服务位置(即,替代当前选择发布的 AD RMS 服务器)。 或者,你可能希望在客户端计算机上启用 RMS 跟踪,以帮助排查启用 RMS 的应用程序的问题。 使用下表来了解可针对 RMS 客户端更改的注册表设置。

任务 设置
如果客户端版本是 1.03102.0221 或更高版本:

控制应用程序数据收集
重要提示:为了尊重用户隐私,作为管理员,你在启用数据收集之前必须征得用户同意。

如果启用数据收集,表示你同意通过 Internet 将数据发送到 Microsoft。 Microsoft 利用此数据保证并改进 Microsoft 产品和服务的质量、安全性和完整性。 例如,Microsoft 会分析性能和可靠性(如使用哪些功能、功能的响应速度、设备性能、用户界面交互和遇到的任何产品问题)。 数据还包括软件(如当前运行的软件)以及 IP 地址的配置信息。

对于版本 1.0.3356 或更高版本:

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft\MSIPC
REG_DWORD: DiagnosticAvailability

对于 1.0.3356 之前的版本:

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft\MSIPC
REG_DWORD: DiagnosticState

值:0 表示(默认)通过使用环境属性 IPC_EI_DATA_COLLECTION_ENABLED 定义应用程序;1 表示禁用;2 表示启用

注意:如果基于 32 位 MSIPC 的应用程序在 64 位版本的 Windows 上运行,则位置为 HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\MSIPC。
仅限 AD RMS:

更新客户端计算机的企业服务位置
更新以下注册表项:

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSIPC\ServiceLocation\EnterpriseCertification
REG_SZ: default

值:http or https>://RMS_Cluster_Name/_wmcs/Certification

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSIPC\ServiceLocation\EnterprisePublishing
REG_SZ: default

值:http or https>://RMS_Cluster_Name/_wmcs/Licensing
启用和禁用跟踪 更新以下注册表项:

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSIPC
REG_DWORD: Trace

值:1 表示启用跟踪,0 表示禁用跟踪(默认)
更改模板刷新的频率(以天为单位) 以下注册表值指定在未设置 TemplateUpdateFrequencyInSeconds 值的情况下,在用户计算机上刷新模板的频率。 如果这两个值都未设置,则应用程序使用 RMS 客户端(版本 1.0.1784.0)下载模板所遵循的默认刷新间隔为 1 天。 在以前的版本中,默认值为 7 天。

客户端模式:

HKEY_CURRENT_USER\Software\Classes\Local Settings\Software\Microsoft\MSIPC
REG_DWORD:TemplateUpdateFrequency

值:指定下载间隔天数的整数值(最小为 1)。

服务器模式

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSIPC\Server\<SID>
REG_DWORD:TemplateUpdateFrequency

值:指定下载间隔天数的整数值(最小为 1)。
更改模板刷新的频率(以秒为单位)

重要提示:如果指定此设置,将忽略以天为单位的模板刷新频率值。 指定其中一项,不要同时指定两项。
以下注册表值指定在用户计算机上刷新模板的频率。 如果未设置此值或者用于更改以天为单位的频率的值 (TemplateUpdateFrequency),则应用程序使用 RMS 客户端(版本 1.0.1784.0)下载模板所遵循的默认刷新间隔为 1 天。 在以前的版本中,默认值为 7 天。

客户端模式:

HKEY_CURRENT_USER\Software\Classes\Local Settings\Software\Microsoft\MSIPC
REG_DWORD:TemplateUpdateFrequencyInSeconds

值:指定下载间隔秒数的整数值(最小为 1)。

服务器模式

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSIPC\Server\<SID>
REG_DWORD:TemplateUpdateFrequencyInSeconds

值:指定下载间隔秒数的整数值(最小为 1)。
仅限 AD RMS:

在下一次发布请求时立即下载模板
在测试和评估期间,你可能希望 RMS 客户端尽快下载模板。 对于此配置,可删除以下注册表项,使 RMS 客户端在下一次发布请求时立即下载模板,而不是按 TemplateUpdateFrequency 注册表设置指定的时间等待:

HKEY_CURRENT_USER\Software\Classes\Local Settings\Software\Microsoft\MSIPC\<Server Name>\Template

注意:Server Name 可以同时具有外部 (corprights.contoso.com) 和内部 (corprights) URL,因此可能具有两个不同的注册表项。
仅限 AD RMS:

启用联合身份验证支持
如果 RMS 客户端使用联合信任连接到 AD RMS 群集,则你必须配置联合主领域。

HKEY_LOCAL_MACHINE\Software\Microsoft\MSIPC\Federation
REG_SZ: FederationHomeRealm

值:此注册表项的值是联合身份验证服务的统一资源标识符 (URI)(例如 <http://TreyADFS.trey.net/adfs/services/trust>)。

请注意:对于此值,请务必指定 http 而不是 https。 此外,如果基于 32 位 MSIPC 的应用程序在 64 位版本的 Windows 上运行,则位置为 HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\MSIPC\Federation。 有关配置示例,请参阅部署 Active Directory Rights Management Services 与 Active Directory 联合身份验证服务
仅限 AD RMS:

支持需要对用户输入进行基于窗体的身份验证的合作伙伴联合身份验证服务器
默认情况下,RMS 客户端在静默模式下运行,并且不需要用户输入。 但是,合作伙伴联合身份验证服务器可能会配置为需要用户输入,例如通过基于表单的身份验证等方式。 在这种情况下,RMS 客户端必须配置为忽略静默模式,以便联合身份验证窗体显示在浏览器窗口中,并提示用户进行身份验证。

HKEY_LOCAL_MACHINE\Software\Microsoft\MSIPC\Federation
REG_DWORD: EnableBrowser

注意:如果联合身份验证服务器配置为使用基于窗体的身份验证,则此项是必需的。 如果联合服务器配置为使用集成 Windows 身份验证,则此项不是必需的。
仅限 AD RMS:

阻止 ILS 服务使用
默认情况下,RMS 客户端支持使用受 ILS 服务保护的内容,但是可以通过设置以下注册表项对它进行配置以阻止此行为。 如果此注册表项设置为阻止 ILS 服务,则对受 ILS 服务保护的内容的任何打开和使用尝试都将返回以下错误:
HRESULT_FROM_WIN32(ERROR_ACCESS_DISABLED_BY_POLICY)

HKEY_CURRENT_USER\Software\Classes\Local Settings\Software\Microsoft\MSIPC
REG_DWORD:DisablePassportCertification

值:1 表示阻止 ILS 使用,0 表示允许 ILS 使用(默认)

管理 RMS 客户端的模板分发

通过模板,用户和管理员可轻松快速地应用 Rights Management 保护,并且 RMS 客户端会自动从其 RMS 服务器或服务下载模板。 如果将模板放在以下文件夹位置中,则 RMS 客户端不会从其默认位置下载任何模板,而是下载放置在该文件夹中的模板。 RMS 客户端可能会继续从其他可用 RMS 服务器下载模板。

客户端模式:%localappdata%\Microsoft\MSIPC\UnmanagedTemplates

服务器模式:%allusersprofile%\Microsoft\MSIPC\Server\UnmanagedTemplates\SID

如果使用此文件夹,除了模板应由 RMS 服务器或服务发布,并且应使用 .xml 文件扩展名以外,没有其他必须遵循的特殊命名约定。 例如,Contoso-Confidential.xml 或 Contoso-ReadOnly.xml 是有效的名称。

仅限 AD RMS:将 RMS 客户端限制为仅使用受信任的 AD RMS 服务器

可以通过对本地计算机上的 Windows 注册表做出以下更改,将 RMS 客户端限制为仅使用受信任的特定 AD RMS 服务器。

将 RMS 客户端限制为仅使用受信任的 AD RMS 服务器

  • HKEY_LOCAL_MACHINE\Software\Microsoft\MSIPC\TrustedServers\

    REG_DWORD:AllowTrustedServersOnly

    值:如果指定一个非零值,则 RMS 客户端只信任在 TrustedServers 列表和 Azure Rights Management 服务中配置的指定服务器。

将成员添加到受信任的 AD RMS 服务器列表

  • HKEY_LOCAL_MACHINE\Software\Microsoft\MSIPC\TrustedServers\

    REG_SZ:URL_or_HostName>

    值:在此注册表项位置中的字符串值可以是 DNS 域名格式(例如 adrms.contoso.com),也可以是指向受信任 AD RMS 服务器的完整 URL(例如 )。 如果指定的 URL 以 https:// 开头,RMS 客户端会使用 SSL 或 TLS 来联系指定的 AD RMS 服务器。

RMS 服务发现

RMS 服务发现可让 RMS 客户端在保护内容之前检查要与哪个 RMS 服务器或服务通信。 当 RMS 客户端使用受保护的内容时,也可能会发生服务发现,不过,这种情况很少出现,因为附加到内容的策略包含首选的 RMS 服务器或服务。 仅当该策略的执行不成功时,客户端才会运行服务发现。

为了执行服务发现,RMS 客户端将检查以下各项:

  1. 本地计算机上的 Windows 注册表:如果注册表中配置了服务发现设置,则先尝试这些设置。

    默认情况下,不会在注册表中配置这些设置,但管理员可以按下一部分所述为 AD RMS 配置它们。 管理员通常在从 AD RMS 到 Azure 信息保护的迁移过程中为 Azure 权限管理服务配置这些设置。

  2. Active Directory 域服务:已加入域的计算机将在 Active Directory 中查询服务连接点 (SCP)。

    如果按下一部分所述注册了一个 SCP,则会将 AD RMS 服务器的 URL 返回给 RMS 客户端使用。

  3. Azure Rights Management 发现服务:RMS 客户端连接到 ,这将提示用户进行身份验证。

    身份验证成功后,将使用进行身份验证所用的用户名(和域)来标识要使用的 Azure 信息保护租户。 会向 RMS 客户端返回该用户帐户要使用的 Azure 信息保护 URL。 URL 采用以下格式:https://YourTenantURL>/_wmcs/licensing>

    例如:5c6bb73b-1038-4eec-863d-49bded473437.rms.na.aadrm.com/_wmcs/licensing

    YourTenantURL> 采用以下格式:{GUID}.rms.[Region].aadrm.com>。在运行 Get-AipServiceConfiguration cmdlet 时,可以通过标识 RightsManagementServiceId 值来找到此值。

注意

此服务发现流有四种重要的例外情况:

  • 移动设备最适合使用云服务,因此默认情况下,它们使用 Azure Rights Management 服务的服务发现 (https://discover.aadrm.com)。 要替代此默认设置以便移动设备使用 AD RMS,而不是 Azure Rights Management 服务,请在 DNS 中指定 SRV 记录,并按 Active Directory Rights Management Services 移动设备扩展中所述安装移动设备扩展。

  • 通过 Azure 信息保护标签调用权限管理服务时,将不会执行服务发现。 相反,会直接在 Azure 信息保护策略配置的标签设置中指定 URL。

  • 当用户从 Office 应用程序启动登录时,将使用进行身份验证所用的用户名(和域)来标识要使用的 Azure 信息保护租户。 在这种情况下,不需要注册表设置,也不会检查 SCP。

  • 为 Office 即点即用桌面应用配置 DNS 重定向后,RMS 客户端可通过拒绝访问以前发现的 AD RMS 群集,查找 Azure 权限管理服务。 此拒绝操作会触发客户端查找 SRV 记录,将客户端重定向到租户的 Azure Rights Management 服务。 此 SRV 记录还允许 Exchange Online 解密受 AD RMS 群集保护的电子邮件。

仅限 AD RMS:使用 Active Directory 启用服务器端服务发现

如果你的帐户拥有足够的权限(AD RMS 服务器的企业管理员和本地管理员),则可以在安装 AD RMS 根群集服务器时自动注册服务连接点 (SCP)。 如果林中已存在 SCP,必须先删除现有 SCP,然后才能注册新的 SCP。

你可以在安装 AD RMS 后,使用以下过程注册和删除 SCP。 在开始之前,请确保你的帐户具有所需的权限(AD RMS 服务器的企业管理员和本地管理员)。

通过在 Active Directory 中注册 SCP 启用 AD RMS 服务发现

  1. 在 AD RMS 服务器上打开 Active Directory Management Services 控制台:

    • 对于 Windows Server 2012 R2 或 Windows Server 2012,请在服务器管理器中,选择“工具”“Active Directory Rights Management Services”。

    • 对于 Windows Server 2008 R2,请选择“开始”“管理工具”“Active Directory Rights Management Services”。

  2. 在 AD RMS 控制台中,右键单击 AD RMS 群集,然后单击“属性”。

  3. 单击“SCP”选项卡

  4. 选中“更改 SCP”复选框

  5. 选择“将 SCP 设置为当前证书群集”选项,然后单击“确定”

使用 Windows 注册表启用客户端服务发现

使用 SCP 或 SCP 不存在时的替代方法是:配置客户端计算机上的注册表,使 RMS 客户端能够找到其 AD RMS 服务器。

使用 Windows 注册表启用客户端 AD RMS 服务发现

  1. 执行 Regedit.exe 打开 Windows 注册表编辑器:

    • 在客户端计算机上的“运行”窗口中,键入 regedit,然后按 Enter 以打开注册表编辑器。
  2. 在注册表编辑器中,导航到 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSIPC

    注意

    如果 32 位应用程序在 64 位计算机上运行,则导航至 HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\MSIPC

  3. 若要创建 ServiceLocation 子项,请右键单击“MSIPC”、指向“新建”、单击“项”,然后键入“ServiceLocation”

  4. 若要创建 EnterpriseCertification 子项,请右键单击“ServiceLocation”、指向“新建”、单击“项”,然后键入“EnterpriseCertification”

  5. 要设置企业证书 URL,请双击“EnterpriseCertification”子项下的“(默认)”值。 出现“编辑字符串”对话框时,对于“值数据”,键入 ,然后单击“确定”。

  6. 要创建 EnterprisePublishing 子项,请右键单击“ServiceLocation”、指向“新建”、单击“项”,然后键入

  7. 要设置企业发布 URL,请双击“EnterprisePublishing”子项下的“(默认)”。 出现“编辑字符串”对话框时,对于“值数据”,键入 ,然后单击“确定”。

  8. 关闭注册表编辑器。

如果 RMS 客户端无法通过查询 Active Directory 找到 SCP 并且注册表中未配置 SCP,则对 AD RMS 的服务发现调用会失败。

重定向授权服务器流量

在某些情况下,你可能需要在服务发现期间重定向流量,例如当两个组织合并后,一个组织中的旧授权服务器已停用,而客户端需要重定向到新的授权服务器。 或者,你要从 AD RMS 迁移到 Azure RMS。 若要启用授权重定向,请使用以下过程。

使用 Windows 注册表启用 AD RMS 授权重定向

  1. 打开 Windows 注册表编辑器:Regedit.exe。

  2. 在注册表编辑器中,导航到以下项之一:

    • 对于 x64 平台上的 64 位版本 Office:HKLM\SOFTWARE\Microsoft\MSIPC\Servicelocation

    • 对于 x64 平台上的 32 位版本 Office:HKLM\SOFTWARE\Wow6432Node\Microsoft\MSIPC\Servicelocation

  3. 通过右键单击“Servicelocation”、指向“新建”、单击“项”,然后键入“LicensingRedirection”,创建一个 LicensingRedirection 子项。

  4. 若要设置授权重定向,请右键单击“LicensingRedirection”子项、选择“新建”,然后选择“字符串值”。 对于“名称”,请指定以前的服务器授权 URL;对于“值”,请指定新的服务器授权 URL

    例如,若要将授权从位于 Contoso.com 的服务器重定向到位于 Fabrikam.com 的服务器,你可以输入以下值:

    名称https://contoso.com/_wmcs/licensing

    https://fabrikam.com/_wmcs/licensing

    注意

    如果旧的授权服务器同时指定了 Intranet URL 和 Extranet URL,则必须在“LicensingRedirection”项下同时为这两个 URL 设置新的名称和值映射

  5. 为所有需要重定向的服务器重复上一步。

  6. 关闭注册表编辑器。