共用方式為

Microsoft Entra UserPrincipalName 填充

本文介绍如何在 Microsoft Entra ID 中填充 UserPrincipalName 属性。 UserPrincipalName 属性值是用户帐户的 Microsoft Entra 用户名。

UPN 术语

本文使用了以下术语:

术语 说明
初始域 Microsoft Entra 租户中的默认域 (partner.onmschina.cn)。 例如,“contoso.partner.onmschina.cn”。
Microsoft 联机电子邮件路由地址 (MOERA) Microsoft Entra ID 从 Microsoft Entra MailNickName 属性计算 MOERA,并将 Entra 初始域Microsoft为“<MailNickName>@<initial 域>”。
本地 mailNickName 属性 Active Directory 中的一个属性,其值表示 Exchange 组织中某个用户的别名。
本地 mail 属性 Active Directory 中的一个属性,其值表示某个用户的电子邮件地址
主要 SMTP 地址 Exchange 收件人对象的主要电子邮件地址。 例如,“SMTP:user@contoso.com”。
备用登录 ID 除 UserPrincipalName 以外的本地属性,例如 mail 属性,用于登录。

什么是 UserPrincipalName?

UserPrincipalName 是基于 Internet 标准 RFC 822 的属性,表示某个用户的 Internet 样式登录名。

UPN 格式

UPN 由 UPN 前缀(用户帐户名)和 UPN 后缀(DNS 域名)组成。 前缀与后缀以“@”符号相联接。 例如“someone@example.com”。 UPN 必须在目录林中的所有安全主体对象之间保持唯一。

Microsoft Entra ID 中的 UPN

Microsoft Entra ID 使用 UPN 让用户登录。 用户可以使用的 UPN 取决于域是否经过验证。 如果域经过验证,则允许具有该后缀的用户名登录到 Microsoft Entra ID。

属性由 Microsoft Entra Connect 同步。 在安装期间,可以查看已验证和未验证的域。

未验证的域

备用登录 ID

在一些环境中,最终用户可能仅知道自己的电子邮件地址,但不知道自己的 UPN。 使用电子邮件地址的原因可能是公司策略或本地业务线应用程序依赖项。

备用登录 ID 允许配置登录体验,用户可以使用其 UPN 以外的属性(如邮件)登录。

若要使用 Microsoft Entra ID 启用备用登录 ID,在使用 Microsoft Entra Connect 时无需执行额外的配置步骤。 可以直接通过向导配置备用 ID。 请参阅“同步”部分中适用于用户的 Microsoft Entra 登录配置。在“用户主体名称”下拉列表中,选择“备用登录 ID”对应的属性。

突出显示“用户主体名称”列表的屏幕截图,你在其中选择了“备用登录 ID”属性。

有关详细信息,请参阅配置备用登录 IDMicrosoft Entra 登录配置

未验证的 UPN 后缀

如果未使用 Microsoft Entra 租户验证本地 UserPrincipalName 属性/备用登录 ID 后缀,则 Microsoft Entra UserPrincipalName 属性值不能具有此域后缀。 Microsoft Entra ID 基于前缀的 Microsoft Entra MailNickName 属性值计算新的 UPN,Microsoft Entra 初始域作为域后缀(<MailNickName>@<initial 域>)。

已验证的 UPN 后缀

如果本地 UserPrincipalName 属性/备用登录 ID 后缀已在 Microsoft Entra 租户中验证,则 Microsoft Entra UserPrincipalName 属性值与本地 UserPrincipalName 属性/备用登录 ID 值相同。

警告

本地 UserPrincipalName 中存在的任何无效字符(例如空格、换行符等)都使同步的 UPN 值失效。 在这种情况下,Microsoft Entra ID 会计算新的 UPN,类似于未使用 Microsoft Entra 租户验证域后缀的方案。

Microsoft Entra MailNickName 属性值计算

由于Microsoft Entra UserPrincipalName 属性值可以重新计算, <MailNickName>@<initial domain>因此必须了解如何计算成为 UPN 前缀的 entra MailNickName 属性值Microsoft。

将用户对象首次同步到 Microsoft Entra 租户后,Microsoft Entra 会按顺序检查以下各项,并将 MailNickName 属性值设置为现有的第一个值:

  • 本地 mailNickName 属性
  • 主要 SMTP 地址的前缀
  • 本地 mail 属性的前缀
  • 本地 userPrincipalName 属性/备用登录 ID 的前缀
  • 次要 SMTP 地址的前缀

将用户对象更新同步到 Microsoft Entra 租户后,仅当本地 mailNickName 属性值发生更新时,Microsoft Entra ID 才会更新 MailNickName 属性值。

重要

仅当已将本地 UserPrincipalName 属性/备用登录 ID 值更新同步到 Microsoft Entra 租户时,Microsoft Entra ID 才会重新计算 UserPrincipalName 属性值。

每当 Microsoft Entra ID 重新计算 UserPrincipalName 属性,并且用户分配了 Exchange 许可证时,新的 UserPrincipalName 值也会添加为辅助 smtp 代理地址。

对于已验证的域更改作(例如,添加新的已验证域或删除现有域),Microsoft Entra ID 还会重新计算租户上所有用户的 UserPrincipalName 属性。 有关详细信息,请参阅疑难解答:针对已验证的域更改审核数据

UPN 方案

下面是根据给定场景来计算 UPN 的示例方案。

应用场景 1:未验证的 UPN 后缀 - 初始同步

Scenario1

本地用户对象:

  • mailNickName:<未设置>

  • proxyAddresses:{SMTP:user1@contoso.com}

  • mail:user2@contoso.com

  • userPrincipalName:user3@contoso.com

首次将用户对象同步到 Microsoft Entra 租户

  • 将 Microsoft Entra MailNickName 属性设置为主要 SMTP 地址前缀。
  • 将 MOERA 设置为 <MailNickName>@<初始域>。
  • 将 Microsoft Entra UserPrincipalName 属性设置为 MOERA。

Microsoft Entra 租户用户对象:

  • MailNickName : user1

  • UserPrincipalName:user1@contoso.partner.onmschina.cn

应用场景 2:未验证的 UPN 后缀 - 设置本地 mailNickName 属性

Scenario2

本地用户对象:

  • mailNickName:user4

  • proxyAddresses:{SMTP:user1@contoso.com}

  • mail:user2@contoso.com

  • userPrincipalName:user3@contoso.com

将本地 mailNickName 属性更新同步到 Microsoft Entra 租户

  • 使用本地 mailNickName 属性更新 Microsoft Entra MailNickName 属性。
  • 由于本地 userPrincipalName 属性未更新,因此 Microsoft Entra UserPrincipalName 属性未更改。

Microsoft Entra 租户用户对象:

  • MailNickName:user4

  • UserPrincipalName:user1@contoso.partner.onmschina.cn

应用场景 3:未验证的 UPN 后缀 - 更新本地 userPrincipalName 属性

Scenario3

本地用户对象:

  • mailNickName:user4

  • proxyAddresses:{SMTP:user1@contoso.com}

  • mail:user2@contoso.com

  • userPrincipalName:user5@contoso.com

将本地 userPrincipalName 属性更新同步到 Microsoft Entra 租户

  • 本地 userPrincipalName 属性更新触发 MOERA 和 Microsoft Entra UserPrincipalName 属性的重新计算。
  • 将 MOERA 设置为 <MailNickName>@<初始域>。
  • 将 Microsoft Entra UserPrincipalName 属性设置为 MOERA。

Microsoft Entra 租户用户对象:

  • MailNickName:user4

  • UserPrincipalName:user4@contoso.partner.onmschina.cn

应用场景 4:未验证的 UPN 后缀 - 更新主要 SMTP 地址和本地 mail 属性

Scenario4

本地用户对象:

  • mailNickName:user4

  • proxyAddresses:{SMTP:user6@contoso.com}

  • mail:user7@contoso.com

  • userPrincipalName:user5@contoso.com

将本地 mail 属性和主要 SMTP 地址的更新同步到 Microsoft Entra 租户

  • 完成用户对象的初始同步后,本地 mail 属性和主要 SMTP 地址的更新不会影响 Microsoft Entra MailNickName 或 UserPrincipalName 属性。

Microsoft Entra 租户用户对象:

  • MailNickName:user4

  • UserPrincipalName:user4@contoso.partner.onmschina.cn

方案 5:已验证的 UPN 后缀 - 更新本地 userPrincipalName 属性后缀

方案 5

本地用户对象:

  • mailNickName:user4

  • proxyAddresses:{SMTP:user6@contoso.com}

  • mail:user7@contoso.com

  • userPrincipalName:user5@verified.contoso.com

将本地 userPrincipalName 属性更新同步到 Microsoft Entra 租户

  • 本地 userPrincipalName 属性更新触发 Microsoft Entra UserPrincipalName 属性的重新计算。
  • 由于 UPN 后缀已在 Microsoft Entra 租户中验证,因此会将 Microsoft Entra UserPrincipalName 属性设置为本地 userPrincipalName 属性。

Microsoft Entra 租户用户对象:

  • MailNickName:user4

  • UserPrincipalName:user5@verified.contoso.com

后续步骤