本文介绍如何在 Microsoft Entra ID 中填充 UserPrincipalName 属性。 UserPrincipalName 属性值是用户帐户的 Microsoft Entra 用户名。
UPN 术语
本文使用了以下术语:
| 术语 | 说明 |
|---|---|
| 初始域 | Microsoft Entra 租户中的默认域 (onmicrosoft.com)。 例如,“contoso.onmicrosoft.com”。 |
| Microsoft 联机电子邮件路由地址 (MOERA) | Microsoft Entra ID 从 Microsoft Entra 的 MailNickName 属性和初始域名计算 MOERA,格式为“<MailNickName>@<初始域名>”。 |
| 本地 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 和 Microsoft Entra 登录配置。
未验证的 UPN 后缀
如果 Microsoft Entra 租户未验证本地的 UserPrincipalName 属性或备用登录 ID 后缀,那么 Microsoft Entra 的 UserPrincipalName 属性值不能包含此域后缀。 Microsoft Entra ID 基于 Microsoft Entra MailNickName 属性值作为前缀计算新的 UPN,并使用 Microsoft Entra 初始域作为域后缀(<MailNickName>@<初始域>)。
已验证的 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>,因此必须了解 Microsoft Entra MailNickName 属性值是如何计算并成为 UPN 前缀的。
将用户对象首次同步到 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 后缀 - 初始同步
本地用户对象:
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.onmicrosoft.com
方案 2:未验证的 UPN 后缀 - 设置本地 mailNickName 属性
本地用户对象:
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.onmicrosoft.com
应用场景 3:未验证的 UPN 后缀 - 更新本地 userPrincipalName 属性
本地用户对象:
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.onmicrosoft.com
方案 4:未验证的 UPN 后缀 - 更新主 SMTP 地址和本地邮件属性
本地用户对象:
mailNickName:user4
proxyAddresses:{SMTP:user6@contoso.com}
mail:user7@contoso.com
userPrincipalName:user5@contoso.com
将本地邮件属性和主 SMTP 地址上的更新同步到 Microsoft Entra 租户
- 在用户对象的初始同步后,对本地邮件属性和主 SMTP 地址的更新不会影响 Microsoft Entra MailNickName 或 UserPrincipalName 属性。
Microsoft Entra 租户用户对象:
MailNickName:user4
UserPrincipalName:user4@contoso.onmicrosoft.com
方案 5:已验证的 UPN 后缀 – 更新本地 userPrincipalName 属性后缀
本地用户对象:
mailNickName:user4
proxyAddresses:{SMTP:user6@contoso.com}
mail:user7@contoso.com
userPrincipalName:user5@verified.contoso.com
将本地 userPrincipalName 属性上的更新同步到 Microsoft Entra 租户
- 本地 userPrincipalName 属性更新触发 Microsoft Entra UserPrincipalName 属性的重新计算。
- 将 Microsoft Entra UserPrincipalName 属性设置为本地 userPrincipalName 属性,因为 UPN 后缀已通过 Microsoft Entra 租户验证。
Microsoft Entra 租户用户对象:
MailNickName:user4
UserPrincipalName:user5@verified.contoso.com