教程:针对自动用户预配来配置 Workday
本教程的目的是介绍将工作人员配置文件从 Workday 预配到本地 Azure Active Directory (AD) 所需执行的步骤。
注意
如果你想要从 Workday 预配的用户需要本地 AD 帐户和 Microsoft Entra 帐户,请使用本教程。
- 如果 Workday 中的用户只需要 Microsoft Entra 帐户(仅限云的用户),请参阅有关配置 Workday 到 Microsoft Entra ID 的用户预配的教程。
- 若要配置将属性(如电子邮件地址、用户名和电话号码)从 Microsoft Entra ID 写回到 Workday,请参阅有关配置 Workday 写回的教程。
以下视频简要概述了规划预配与 Workday 的集成时所涉及的步骤。
概述
Microsoft Entra 用户预配服务与 Workday Human Resources API 集成,以便能够预配用户帐户。 Microsoft Entra 用户预配服务支持的 Workday 用户预配工作流可将以下人力资源和标识生命周期管理方案自动化:
招聘新员工 - 将新员工添加到 Workday 后,Active Directory、Microsoft Entra ID 以及(可选)Microsoft 365 和 Microsoft Entra ID 支持的其他 SaaS 应用程序中会自动创建一个用户帐户,并将 IT 托管的联系人信息写回到 Workday。
员工特性和个人资料更新 - 在 Workday 中更新员工记录(例如其姓名、职称或上司)后,Active Directory、Microsoft Entra ID、(可选)Microsoft 365 和 Microsoft Entra ID 支持的其他 SaaS 应用程序中会自动更新相应员工的用户帐户。
员工离职 - 当某个员工在 Workday 离职时,Active Directory、Microsoft Entra ID、(可选)Microsoft 365 和 Microsoft Entra ID 支持的其他 SaaS 应用程序中会自动禁用其用户帐户。
员工返聘 - 当 Workday 返聘某位员工时,该员工的旧帐户可自动重新激活或重新预配到 Active Directory、Microsoft Entra ID、Microsoft 365 和 Microsoft Entra ID 支持的其他 SaaS 应用程序(其中,具体操作由你的偏好而定,且后两类应用可选配)。
新增功能
本部分收集了 Workday 集成的最新增强功能。 如需查看包含综合更新、计划变更和存档的列表,请访问 Microsoft Entra ID 有哪些新增功能?
2020 年 10 月 - 对 Workday 启用了按需预配:使用按需预配,你现在可测试 Workday 中特定用户配置文件的端到端预配,以验证你的属性映射和表达式逻辑。
2020 年 5 月 - 能够将电话号码写回到 Workday: 除了电子邮件和用户名外,现在还可以将工作电话号码和移动电话号码从 Microsoft Entra ID 写回到 Workday。 有关更多详细信息,请参阅写回应用教程。
2020 年 4 月 - 支持最新版本的 Workday Web 服务 (WWS) API: 每年 3 月和 9 月,Workday 都会提供功能丰富的更新,帮助你满足业务目标和不断变化的劳动力需求。 为了跟上 Workday 提供的新功能,可以直接指定希望在连接 URL 中使用的 WWS API 版本。 要详细了解如何指定 Workday API 版本,请参阅有关配置 Workday 连接的部分。
此用户预配解决方案最适合哪些对象?
此 Workday 用户预配解决方案非常适合以下对象:
需要使用预建的、基于云的解决方案进行 Workday 用户预配的组织
需要将用户预配从 Workday 定向到 Active Directory 或 Microsoft Entra ID 的组织
要求使用从 Workday HCM 模块获取的数据预配用户的组织(请参阅 Get_Workers)
需要仅根据 Workday HCM 模块中检测到的更改信息,将用户的加入、移动和离开同步到一个或多个 Active Directory 林、域和 OU 的组织(请参阅 Get_Workers)
使用 Microsoft 365 收发电子邮件的组织
解决方案体系结构
本节介绍适用于常见混合环境的端到端用户预配解决方案体系结构。 有两个相关的流:
- 权威 HR 数据流 - 从 Workday 到本地 Active Directory:在此流中,员工事件(如新员工入职、换岗、离职等)首先发生在云 Workday HR 租户中,然后事件数据通过 Microsoft Entra ID 和预配代理流入本地 Active Directory。 根据事件的不同,可能会导致在 AD 中创建/更新/启用/禁用操作。
- 写回流 - 从本地 Active Directory 到 Workday:在 Active Directory 中完成帐户创建后,将通过 Microsoft Entra Connect 实现与 Microsoft Entra ID 的同步,并且电子邮件、用户名和电话号码等信息可写回到 Workday。
端到端用户数据流
- HR 团队在 Workday HCM 中执行工作人员事务(入职者/换岗者/离职者或新雇员/换岗/离职)
- Microsoft Entra 预配服务运行来自 Workday HR 的标识的计划同步,并确定需要进行处理以供与本地 Active Directory 域服务同步的更改。
- Microsoft Entra 预配服务使用包含 Microsoft Entra 帐户创建/更新/启用/禁用操作的请求有效负载调用 Microsoft Entra Connect 预配代理。
- Microsoft Entra Connect 预配代理使用服务帐户来添加/更新 AD 帐户数据。
- Microsoft Entra Connect / AD Sync 引擎运行增量同步以获取 AD 中的更新。
- Active Directory 更新与 Microsoft Entra ID 同步。
- 如果已配置 Workday Writeback 应用,则该应用会将电子邮件、用户名和电话号码等属性写回 Workday。
计划部署
配置 Workday 到 Active Directory 的用户预配需要涵盖不同方面的大量规划,例如:
- Microsoft Entra Connect 预配代理的设置
- 要部署的 Workday 到 AD 用户预配应用的数目
- 选择合适的匹配标识符、属性映射、转换和范围筛选器
有关综合指导原则和推荐的最佳做法,请参阅云 HR 部署计划。
在 Workday 中配置集成系统用户
所有 Workday 预配连接器的一项常见要求是,需使用 Workday 集成系统用户的凭据连接到 Workday 人力资源 API。 本部分介绍如何在 Workday 中创建集成系统用户,它包含以下部分:
注意
可以绕过此过程并改用 Workday 管理员帐户作为系统集成帐户。 在演示中这样做不会有任何问题,但是,对于生产部署,我们不建议这样做。
创建集成系统用户
创建集成系统用户:
使用管理员帐户登录到 Workday 租户。 在“Workday 应用程序”的搜索框中,输入“创建用户”,然后单击“创建集成系统用户” 。
通过为新的集成系统用户提供用户名和密码,完成“创建集成系统用户”任务。
- 使“下次登录时需要新密码”选项处于未选中状态,因为此用户以编程方式登录。
- 将“会话超时(分钟)”保留为默认值 0,以防止用户会话过早超时。
- 选择选项“不允许 UI 会话”,因为它提供了额外的安全层,可防止拥有集成系统密码的用户登录 Workday。
创建集成安全组
在此步骤中,你将在 Workday 中创建不受约束或受约束的集成系统安全组,并将在上一步中创建的集成系统用户分配给该组。
创建安全组:
在搜索框中输入“创建安全组”,然后单击“创建安全组”。
完成“创建安全组”任务。
Workday 中有两种类型的安全组:
- 不受约束: 安全组的所有成员均可访问受该安全组保护的所有数据实例。
- 受约束: 所有安全组成员均可对该安全组能访问的部分数据实例(行)进行基于上下文的访问。
请咨询 Workday 集成合作伙伴,从而为集成选择适当的安全组类型。
在知道组类型之后,请从“租户安全组类型”的下拉列表中选择“集成系统安全组(不受约束)”或“集成系统安全组(受约束)” 。
安全组创建成功后,将显示可以为安全组分配成员的页面。 将在上一步中新建的集成系统用户添加到此安全组中。 如果要使用受约束的安全组,则需要选择相应的组织范围。
配置域安全策略权限
此步骤将向安全组授予员工数据的“域安全性”策略权限。
配置域安全策略权限:
在搜索框中输入“安全组成员身份和访问”,并单击该报表链接。
搜索在上一步骤中创建的安全组并将其选中。
单击组名旁的省略号 (
...
),然后从菜单中选择“安全组”>“维护安全组的域权限”在“集成权限”下,将以下域添加到“允许 Put 访问的域安全策略”列表中
- 外部帐户预配
- 工作人员数据:公职人员报表
- 个人数据:工作联系人信息(如果你计划将联系人数据从 Microsoft Entra ID 写回 Workday,则它为必需项)
- Workday 帐户(如果你计划将用户名/UPN 从 Microsoft Entra ID 写回 Workday,则它为必需项)
在“集成权限”下,将以下域添加到“允许 Get 访问的域安全策略”列表中
- 工作人员数据:工作人员
- 工作人员数据:所有职位
- 工作人员数据:当前人员配备信息
- 工作人员数据:工作人员个人资料中的职称
- 工作人员数据:合格的工作人员(可选 - 添加此项以检索用于预配的工作人员资格数据)
- 工作人员数据:技能和经验(可选 - 添加此项以检索用于预配的工作人员技能数据)
完成上述步骤后,随即会显示权限屏幕,如下所示:
在下一屏幕上单击“确定”和“完成”以完成配置 。
配置业务流程安全策略权限
此步骤将向安全组授予员工数据的“业务流程安全性”策略权限。
注意
只有设置 Workday Writeback 应用连接器才需要此步骤。
配置业务流程安全策略权限:
在搜索框中输入“业务流程策略”,然后单击链接“编辑业务流程安全策略”任务 。
在“业务流程类型”文本框中,搜索“联系人”并选择“工作联系人更改”业务流程,然后单击“确定” 。
在“编辑业务流程安全策略”页面上,滚动到“更改工作联系人信息 (Web 服务)”部分 。
选择新的集成系统安全组并将其添加到可以发起 Web 服务请求的安全组列表中。
单击“完成”。
激活安全策略更改
激活安全策略更改:
在搜索框中输入“激活”,然后单击链接“激活挂起的安全策略更改”。
通过输入用于审核的注释,然后单击“确定”,开始“激活挂起的安全策略更改”任务。
选中“确认”复选框,然后单击“确定”,完成下一屏幕上的任务。
预配代理安装先决条件
继续下一部分之前,请查看预配代理安装先决条件。
配置从 Workday 到 Active Directory 的用户预配
此部分按步骤介绍如何将用户帐户从 Workday 预配到集成范围内的每个 Active Directory 域。
第 1 部分:添加预配连接器应用并下载预配代理
若要配置 Workday 到 Active Directory 的预配:
至少以云应用程序管理员身份登录到 Microsoft Entra 管理中心。
浏览至“标识”>“应用程序”>“企业应用程序”>“新建应用程序”。
搜索“Workday 到 Active Directory 的用户预配”,然后从库中添加该应用。
添加应用并显示应用详细信息屏幕后,请选择“预配”。
将“预配模式”更改为“自动”。
单击显示的信息横幅以下载预配代理。
第 2 部分:安装和配置本地预配代理
要预配到本地 Active Directory,必须在可通过网络访问所需 Active Directory 域的已加入域的服务器上安装预配代理。
将下载的代理安装程序传输到服务器主机,并按照安装代理部分中列出的步骤完成代理配置。
第 3 部分:在预配应用中,配置与 Workday 和 Active Directory 的连接
在此步骤中,我们将建立与 Workday 和 Active Directory 的连接。
至少以云应用程序管理员身份登录到 Microsoft Entra 管理中心。
浏览到“标识”>“应用程序”>“企业应用程序”> 在第一部分中创建的 Workday 到 Active Directory 用户预配应用。
按如下所述完成“管理员凭据”部分:
Workday 用户名 - 输入 Workday 集成系统帐户的用户名并附加租户域名。 内容应该如下所示:username@tenant_name
Workday 密码 - 输入 Workday 集成系统帐户的密码
Workday Web Services API URL - 输入租户的 Workday Web 服务终结点的 URL。 该 URL 用于确定连接器使用的 Workday Web Services API 的版本。
URL 格式 使用的 WWS API 版本 需要更改 XPATH https://####.workday.com/ccx/service/tenantName v21.1 否 https://####.workday.com/ccx/service/tenantName/Human_Resources v21.1 否 https://####.workday.com/ccx/service/tenantName/Human_Resources/v##.# v##.# 是 注意
如果 URL 中未指定版本信息,则该应用使用 Workday Web Services (WWS) v21.1,且无需对应用附带的默认 XPATH API 表达式进行更改。 若要使用特定的 WWS API 版本,请在 URL 中指定版本号
示例:https://wd3-impl-services1.workday.com/ccx/service/contoso4/Human_Resources/v34.0
如果你使用的是 WWS API v30.0+,请在打开预配作业之前,更新“属性映射”->“高级选项”->“编辑 Workday 的属性列表”下的“XPATH API 表达式”,具体参阅管理配置和 Workday 属性引用部分。Active Directory 林 - 向代理注册时使用的 Active Directory 域的“名称”。 使用下拉列表选择用于预配的目标域。 此值通常为如下所示的字符串:contoso.com
Active Directory 容器 - 输入默认情况下代理应在其中创建用户帐户的容器 DN。 示例:OU=Standard Users,OU=Users,DC=contoso,DC=test
注意
如果未在属性映射中配置 parentDistinguishedName 属性,则此设置仅对用户帐户创建起作用。 此设置不用于用户搜索或更新操作。 整个域子树属于搜索操作的范围。
通知电子邮件 - 输入电子邮件地址,然后选中“如果失败,则发送电子邮件”复选框。
注意
如果预配作业进入隔离状态,Microsoft Entra 预配服务将发送电子邮件通知。
单击“测试连接”按钮。 如果连接测试成功,请单击顶部的“保存”按钮。 如果连接测试失败,请仔细检查代理设置上配置的 Workday 凭据和 AD 凭据是否有效。
凭据成功保存后,“映射”部分会显示默认映射“将 Workday 员工同步到本地 Active Directory”
第 4 部分:配置属性映射
在本部分,你将配置用户数据如何从 Workday 流入 Active Directory。
在“预配”选项卡的“映射”下,单击“将 Workday 工作人员同步到本地 Active Directory” 。
在“源对象范围”字段中,可以通过定义一组基于属性的筛选器,选择 Workday 中要预配到 AD 的用户集范围。 默认范围是“Workday 中的所有用户”。 示例筛选器:
示例:将范围限定为工作人员 ID 为 1000000 到 2000000 的用户(不包括 2000000)
属性:WorkerID
运算符:REGEX Match
值:(1[0-9][0-9][0-9][0-9][0-9][0-9])
示例:仅限员工和非临时工
属性:EmployeeID
运算符:不为 NULL
提示
首次配置预配应用时,需要测试和验证属性映射和表达式,以确保它提供所需的结果。 Microsoft 建议使用“源对象范围”下的范围筛选器和按需预配来测试 Workday 中少量测试用户的映射。 验证确保映射正常工作后,可删除筛选器,也可逐渐扩大范围以包含更多用户。
注意
预配引擎的默认行为是禁用/删除超出范围的用户。 这可能不适合于 Workday 到 AD 集成。 若要替代此默认行为,请参阅跳过删除超出范围的用户帐户
在“目标对象操作”字段中,可全局筛选要对 Active Directory 执行的操作。 “创建”和“更新”是最常见的操作。
在“属性映射”部分中,可以定义 Workday 属性到 Active Directory 属性的各个映射。
单击现有的属性映射可将其更新,单击屏幕底部的“添加新映射”可添加新的映射。 单个属性映射支持以下属性:
映射类型
直接映射 - 将 Workday 属性的值按原样写入 AD 属性
常量映射 - 将静态常量字符串值写入 AD 属性
表达式 – 可以基于一个或多个 Workday 属性将自定义值写入 AD 属性。 有关详细信息,请参阅这篇有关表达式的文章。
源属性 – Workday 中的用户属性。 如果你查找的属性不存在,请参阅自定义 Workday 用户属性列表。
默认值 – 可选。 如果源属性的值为空,那么映射会改为写入此值。 最常见的配置是将此项留空。
目标属性 - Active Directory 中的用户属性。
使用此属性匹配对象 – 是否应使用此映射唯一标识 Workday 与 Active Directory 之间的用户。 该值通常是在 Workday 的“工作人员 ID”字段中设置的,它通常映射到 Active Directory 中的某个“员工 ID”属性。
匹配优先级 – 可设置多个匹配属性。 当存在多个匹配属性时,会按照此字段定义的顺序进行评估。 一旦找到匹配,就不会进一步评估其他匹配属性。
应用此映射
始终 – 对用户创建和更新操作均应用此映射
仅创建期间 - 仅对用户创建操作应用此映射
若要保存映射,请单击“属性映射”部分顶部的“保存”。
下面是 Workday 与 Active Directory 之间的一些属性映射示例,还显示一些常用的表达式
可根据一个或多个 Workday 源属性,使用映射到 parentDistinguishedName 属性的表达式将用户预配到不同的 OU。 以下示例根据用户所在的城市,将用户放入不同的 OU。
Active Directory 中的 userPrincipalName 属性是使用重复数据删除函数 SelectUniqueValue 生成的,该函数会检查目标 AD 域中是否存在生成的值,且仅在值唯一时才设置它。
此处提供了有关编写表达式的文档。 此部分中包括有关如何删除特殊字符的示例。
WORKDAY 属性 | ACTIVE DIRECTORY 属性 | 匹配 ID? | 创建/更新 |
---|---|---|---|
WorkerID | EmployeeID | 是 | 仅在创建时写入 |
PreferredNameData | cn | 仅在创建时写入 | |
SelectUniqueValue( Join("@", Join(".", [FirstName], [LastName]), "contoso.com"), Join("@", Join(".", Mid([FirstName], 1, 1), [LastName]), "contoso.com"), Join("@", Join(".", Mid([FirstName], 1, 2), [LastName]), "contoso.com")) | userPrincipalName | 仅在创建时写入 | |
Replace(Mid(Replace([UserID], , "([\\/\\\\\\[\\]\\:\\;\\|\\=\\,\\+\\*\\?\\<\\>])", , "", , ), 1, 20), , "(\\.)*$", , "", , ) |
sAMAccountName | 仅在创建时写入 | |
Switch([Active], , "0", "True", "1", "False") | accountDisabled | 创建 + 更新 | |
名字 | givenName | 创建 + 更新 | |
姓氏 | sn | 创建 + 更新 | |
PreferredNameData | displayName | 创建 + 更新 | |
Company | company | 创建 + 更新 | |
SupervisoryOrganization | department | 创建 + 更新 | |
ManagerReference | manager | 创建 + 更新 | |
BusinessTitle | title | 创建 + 更新 | |
AddressLineData | streetAddress | 创建 + 更新 | |
Municipality | l | 创建 + 更新 | |
CountryReferenceTwoLetter | co | 创建 + 更新 | |
CountryReferenceTwoLetter | c | 创建 + 更新 | |
CountryRegionReference | st | 创建 + 更新 | |
WorkSpaceReference | physicalDeliveryOfficeName | 创建 + 更新 | |
PostalCode | postalCode | 创建 + 更新 | |
PrimaryWorkTelephone | telephoneNumber | 创建 + 更新 | |
Fax | facsimileTelephoneNumber | 创建 + 更新 | |
Mobile | mobile | 创建 + 更新 | |
LocalReference | preferredLanguage | 创建 + 更新 | |
Switch([Municipality], "OU=Default Users,DC=contoso,DC=com", "Dallas", "OU=Dallas,OU=Users,DC=contoso,DC=com", "Austin", "OU=Austin,OU=Users,DC=contoso,DC=com", "Seattle", "OU=Seattle,OU=Users,DC=contoso,DC=com", "London", "OU=London,OU=Users,DC=contoso,DC=com") | parentDistinguishedName | 创建 + 更新 |
完成属性映射配置后,可使用按需预配预配测试单个用户的预配,然后启用并启动用户预配服务。
启用并启动用户预配
完成 Workday 预配应用配置,并且已使用按需预配验证单个用户的预配后,可以启用预配服务。
提示
默认情况下,启用预配服务时,它会为范围中的所有用户启动预配操作。 如果映射出错或存在 Workday 数据问题,则预配作业可能会失败并转入隔离状态。 要避免这种情况,最佳做法是先配置“源对象范围”筛选器并使用按需预配对少数测试用户测试你的属性映射,然后再为所有用户启动完全同步。 验证确保映射正常工作且获得所需结果后,可删除筛选器或逐渐扩大范围以包含更多用户。
转到“预配”边栏选项卡,单击“开始预配” 。
此操作将启动初始同步,该过程会耗时数小时,具体时间取决于 Workday 租户中的用户数。 可检查进度条来跟踪同步周期的进度。
无论何时,都可以检查 Microsoft Entra 管理中心中的“预配”选项卡,查看预配服务执行的操作。 预配日志会列出预配服务执行的所有单个同步事件,例如,正在从 Workday 中读出哪些用户,随后将其添加或更新到 Active Directory。 要了解如何查看预配日志并解决预配错误,请参阅“故障排除”部分。
完成初始同步后,系统会在“预配”选项卡中写入一份审核摘要报告,如下所示。
常见问题(FAQ)
解决方案功能问题
预配代理问题
Workday 到 AD 属性映射和配置问题
解决方案功能问题
处理来自 Workday 的新员工时,解决方案如何在 Active Directory 中为新用户帐户设置密码?
当本地预配代理收到新建 AD 帐户的请求时,它会自动生成一个复杂的随机密码,旨在满足 AD 服务器定义的密码复杂性要求,并将其设置到用户对象上。 此密码未记录在任何位置。
解决方案是否支持在预配操作完成后发送电子邮件通知?
不支持,当前版本不支持在预配操作完成后发送电子邮件通知。
解决方案是否在 Microsoft Entra 云端或预配代理层中缓存 Workday 用户个人资料?
不会,该解决方案不维护用户个人资料的缓存。 Microsoft Entra 预配服务只充当数据处理器,它从 Workday 读取数据并写入目标 Active Directory 或 Microsoft Entra ID。 有关用户隐私和数据保留期的详细信息,请参阅管理个人数据部分。
解决方案是否支持将本地 AD 组分配给用户?
当前不支持此功能。 建议的解决方法是部署 PowerShell 脚本,该脚本用于查询 Microsoft Graph API 终结点,以获取预配日志数据,并使用该数据触发组分配等方案。 可将此 PowerShell 脚本附加到任务计划程序,并将其部署到运行预配代理的框中。
解决方案使用哪些 Workday API 来查询和更新 Workday 工作人员个人资料?
该解决方案当前使用以下 Workday API:
“管理员凭据”部分中使用的“Workday Web 服务 API URL”格式确定 Get_Workers 使用的 API 版本
- 如果 URL 格式为:https://####.workday.com/ccx/service/tenantName,则使用 API v21.1。
- 如果 URL 格式为:https://####.workday.com/ccx/service/tenantName/Human_Resources,则使用 API v21.1
- 如果 URL 格式为:https://####.workday.com/ccx/service/tenantName/Human_Resources/v##.#,则使用指定 API 版本。 (例如:如果指定了 v34.0,则会使用它。)
Workday 电子邮件写回功能使用 Change_Work_Contact_Information (v30.0)
Workday 用户名写回功能使用 Update_Workday_Account (v31.2)
能否使用两个 Microsoft Entra 租户配置 Workday HCM 租户?
可以,支持该项配置。 下面是用于配置此方案的大致步骤:
- 部署预配代理 #1 并将其注册到 Microsoft Entra 租户 #1。
- 部署预配代理 #2 并将其注册到 Microsoft Entra 租户 #2。
- 根据每个预配代理管理的“子域”,使用域来配置每个代理。 一个代理可以处理多个域。
- 在 Microsoft Entra 管理中心中,在每个租户中将 Workday 设置为 AD 用户设置应用,并使用各自的域进行配置。
如何建议改进功能或请求与 Workday 和 Microsoft Entra 集成相关的新功能?
你的反馈非常宝贵,它可帮助我们制定未来版本和增强功能的开发方向。 我们乐于收到任何反馈,请在 Microsoft Entra ID 反馈论坛提交创意或改进意见。 要了解与 Workday 集成相关的具体反馈,请选择“SaaS 应用程序”类别,再使用关键词“Workday”进行搜索,以查找与 Workday 相关的现有反馈 。
在建议新想法时,请查看是否已有人提出了类似功能的建议。 如果是,则你可投票支持该功能或增强功能请求。 你还可对特定用例发表评论,以表明你的支持态度并指出该功能在哪些方面对你有价值。
预配代理问题
预配代理的正式版是什么?
请参阅Microsoft Entra Connect 预配代理:版本发行历史记录,了解预配代理的最新正式发行版本。
如何知道我的预配代理的版本?
- 登录到安装有预配代理的 Windows Server。
- 转到“控制面板”->“卸载或更改程序”菜单。
- 查找与条目“Microsoft Entra Connect 预配代理”相对应的版本。
Microsoft 是否会自动拉取预配代理更新?
会,如果 Windows 服务“ Microsoft Entra Connect 代理更新程序”启动并运行,则 Microsoft 会自动更新预配代理。
能否在运行 Microsoft Entra Connect 的同一服务器上安装预配代理?
是,可在运行 Microsoft Entra Connect 的同一服务器上安装预配代理。
配置时,预配代理会提示输入 Microsoft Entra 管理员凭据。 代理会将凭据存储在本地服务器上吗?
配置过程中,预配代理会提示输入 Microsoft Entra 管理员凭据,它们仅用于连接到 Microsoft Entra 租户。 它不会将凭据存储在本地服务器上。 但它确实会保留凭据,以用于连接到本地 Windows 密码保管库中的本地 Active Directory 域。
如何将预配代理配置为使用代理服务器来处理出站 HTTP 通信?
预配代理支持使用出站代理。 可通过编辑代理配置文件“C:\Program Files\Microsoft Azure AD Connect Provisioning Agent\AADConnectProvisioningAgent.exe.config”对其进行配置。在文件的末尾添加以下行,恰好添加在尾随的 </configuration>
标记前面。
将变量 [proxy-server] 和 [proxy-port] 替换为代理服务器名称和端口值。
<system.net>
<defaultProxy enabled="true" useDefaultCredentials="true">
<proxy
usesystemdefault="true"
proxyaddress="http://[proxy-server]:[proxy-port]"
bypassonlocal="true"
/>
</defaultProxy>
</system.net>
如何确保预配代理能够与 Microsoft Entra 租户进行通信且防火墙不阻止代理所需的端口?
还可以检查所有必需端口是否已打开。
能否将一个预配代理配置为预配多个 AD 域?
是,只要代理可感知到各自的域控制器,就可将一个预配代理配置为处理多个 AD 域。 Microsoft 建议设置一个包含 3 个预配代理的组,它提供同一组 AD 域来确保高可用性并提供故障转移支持。
如何取消注册与我的预配代理相关联的域?
*,获取 Microsoft Entra 租户的租户 ID。
登录到运行预配代理的 Windows Server。
以 Windows 管理员身份打开 PowerShell。
切换到包含注册脚本的目录,并运行以下命令,将 [租户 ID] 参数替换为租户 ID 的值。
cd "C:\Program Files\Microsoft Azure AD Connect Provisioning Agent\RegistrationPowershell\Modules\PSModulesFolder" Import-Module "C:\Program Files\Microsoft Azure AD Connect Provisioning Agent\RegistrationPowershell\Modules\PSModulesFolder\MicrosoftEntraPrivateNetworkConnectorPSModule.psd1" Get-PublishedResources -TenantId "[tenant ID]"
在显示的代理列表中,从其 resourceName 等于你的 AD 域名的资源中复制“
id
”字段的值。将该 ID 值粘贴到此命令中,并在 PowerShell 中执行该命令。
Remove-PublishedResource -ResourceId "[resource ID]" -TenantId "[tenant ID]"
重新运行代理配置向导。
需要重新配置之前分配到此域的其他所有代理。
如何卸载预配代理?
- 登录到安装有预配代理的 Windows Server。
- 转到“控制面板”->“卸载或更改程序”菜单
- 卸载以下程序:
- Microsoft Entra Connect 预配代理
- Microsoft Entra Connect 代理更新程序
- Microsoft Entra Connect 预配代理包
Workday 到 AD 属性映射和配置问题
如何备份或导出 Workday 预配属性映射和架构的工作副本?
可使用 Microsoft Graph API 来导出 Workday 用户预配配置。 有关详细信息,请参考导出和导入 Workday 用户预配属性映射配置部分中的步骤。
我在 Workday 和 Active Directory 中具有自定义属性。 我要如何配置解决方案以使用我的自定义属性?
该解决方案支持自定义 Workday 和 Active Directory 属性。 要将自定义属性添加到映射架构,请打开“属性映射”边栏选项卡,再向下滚动以展开“显示高级选项”部分 。
要添加自定义 Workday 属性,请选择“编辑 Workday 属性列表”选项;要添加自定义 AD 属性,请选择“编辑本地 Active Directory 属性列表”选项 。
另请参阅:
如何将解决方案配置为根据 Workday 更改仅更新 AD 中的属性,而不创建任何新的 AD 帐户?
可通过设置“属性映射”边栏选项卡中的“目标对象操作”来实现此配置,如下所示 :
仅针对从 Workday 流向 AD 的更新操作勾选“更新”复选框。
能否将用户的照片从 Workday 预配到 Active Directory?
该解决方案目前不支持设置二进制文件属性,例如 Active Directory 中的 thumbnailPhoto 和 jpegPhoto。
如何在用户同意公开使用后使用 Workday 中的手机号码?
请转到 Workday 预配应用的“预配”边栏选项卡。
单击“属性映射”
在“映射”下,选择“将 Workday 工作人员同步到本地 Active Directory”(或“将 Workday 工作人员同步到 Microsoft Entra ID)。
在“属性映射”页面上,向下滚动并选中“显示高级选项”框。 单击“编辑 Workday 属性列表”
在打开的边栏选项卡中,找到“Mobile”属性并单击该行,从而编辑 API 表达式
将 API 表达式替换为下列的新表达式,后者仅当 Workday 中的“公开使用标志”设置为“True”时,才会检索工作手机号码。
wd:Worker/wd:Worker_Data/wd:Personal_Data/wd:Contact_Data/wd:Phone_Data[translate(string(wd:Phone_Device_Type_Reference/@wd:Descriptor),'abcdefghijklmnopqrstuvwxyz','ABCDEFGHIJKLMNOPQRSTUVWXYZ')='MOBILE' and translate(string(wd:Usage_Data/wd:Type_Data/wd:Type_Reference/@wd:Descriptor),'abcdefghijklmnopqrstuvwxyz','ABCDEFGHIJKLMNOPQRSTUVWXYZ')='WORK' and string(wd:Usage_Data/@wd:Public)='1']/@wd:Formatted_Phone
保存属性列表。
保存属性映射。
清除当前状态并重启完全同步。
如何根据用户的部门/国家/地区/城市特性在 AD 中设置显示名的格式并处理区域差异问题?
通常要求在 AD 中配置 displayName 属性,这样它才会提供用户所属部门和国家/地区的相关信息。 例如,如果 John Smith 就职于美国市场营销部门,你会希望他的 displayName 显示为“Smith, John (Marketing-US)”。
下面介绍了如何应对有关构建 CN 或 displayName 来包含公司、业务单位、城市或国家/地区等属性的此类要求。
每个 Workday 属性均通过基础 XPATH API 表达式进行检索,后者可在“属性映射”->“高级部分”->“编辑 Workday 属性列表”中进行配置。 下面是 Workday 的 PreferredFirstName、PreferredLastName、Company 和 SupervisoryOrganization 属性的默认 XPATH API 表达式。
Workday 属性 API XPath 表达式 PreferredFirstName wd:Worker/wd:Worker_Data/wd:Personal_Data/wd:Name_Data/wd:Preferred_Name_Data/wd:Name_Detail_Data/wd:First_Name/text() PreferredLastName wd:Worker/wd:Worker_Data/wd:Personal_Data/wd:Name_Data/wd:Preferred_Name_Data/wd:Name_Detail_Data/wd:Last_Name/text() Company wd:Worker/wd:Worker_Data/wd:Organization_Data/wd:Worker_Organization_Data[wd:Organization_Data/wd:Organization_Type_Reference/wd:ID[@wd:type='Organization_Type_ID']='Company']/wd:Organization_Reference/@wd:Descriptor SupervisoryOrganization wd:Worker/wd:Worker_Data/wd:Organization_Data/wd:Worker_Organization_Data/wd:Organization_Data[wd:Organization_Type_Reference/wd:ID[@wd:type='Organization_Type_ID']='Supervisory']/wd:Organization_Name/text() 咨询 Workday 团队,确认上述 API 表达式对 Workday 租户配置而言有效。 如有必要,可按自定义 Workday 用户属性列表部分中所述进行编辑。
同样地,使用以下 XPATH 检索 Workday 中的国家/地区信息:wd:Worker/wd:Worker_Data/wd:Employment_Data/wd:Position_Data/wd:Business_Site_Summary_Data/wd:Address_Data/wd:Country_Reference
下面是“Workday 属性列表”部分中提供的 5 个与国家/地区相关的属性。
Workday 属性 API XPath 表达式 CountryReference wd:Worker/wd:Worker_Data/wd:Employment_Data/wd:Position_Data/wd:Business_Site_Summary_Data/wd:Address_Data/wd:Country_Reference/wd:ID[@wd:type='ISO_3166-1_Alpha-3_Code']/text() CountryReferenceFriendly wd:Worker/wd:Worker_Data/wd:Employment_Data/wd:Position_Data/wd:Business_Site_Summary_Data/wd:Address_Data/wd:Country_Reference/@wd:Descriptor CountryReferenceNumeric wd:Worker/wd:Worker_Data/wd:Employment_Data/wd:Position_Data/wd:Business_Site_Summary_Data/wd:Address_Data/wd:Country_Reference/wd:ID[@wd:type='ISO_3166-1_Numeric-3_Code']/text() CountryReferenceTwoLetter wd:Worker/wd:Worker_Data/wd:Employment_Data/wd:Position_Data/wd:Business_Site_Summary_Data/wd:Address_Data/wd:Country_Reference/wd:ID[@wd:type='ISO_3166-1_Alpha-2_Code']/text() CountryRegionReference wd:Worker/wd:Worker_Data/wd:Employment_Data/wd:Position_Data/wd:Business_Site_Summary_Data/wd:Address_Data/wd:Country_Region_Reference/@wd:Descriptor 咨询 Workday 团队,确认上述 API 表达式对 Workday 租户配置而言有效。 如有必要,可按自定义 Workday 用户属性列表部分中所述进行编辑。
要构建正确的属性映射表达式,请确定哪个 Workday 属性“权威地”表示用户的名字、姓氏、国家/地区和部门。 假设属性分别是 PreferredFirstName、PreferredLastName、CountryReferenceTwoLetter 和 SupervisoryOrganization 。 可使用此方法为 AD 的 displayName 属性构建表达式(如下所示),以获取显示名称,例如“Smith, John (Marketing-US)” 。
Append(Join(", ",[PreferredLastName],[PreferredFirstName]), Join(""," (",[SupervisoryOrganization],"-",[CountryReferenceTwoLetter],")"))
一旦具有正确的表达式,即可编辑属性映射表并修改 displayName 属性映射,如下所示:
扩充上面的示例,假设你想要将 Workday 中的城市名称转换为速记值,再用它来构建显示名称,例如“Smith, John (CHI)”或“Doe, Jane (NYC)”,然后就可通过采用 Workday“Municipality”属性作为判定变量的 Switch 表达式来检索该结果 。
Switch ( [Municipality], Join(", ", [PreferredLastName], [PreferredFirstName]), "Chicago", Append(Join(", ",[PreferredLastName], [PreferredFirstName]), "(CHI)"), "New York", Append(Join(", ",[PreferredLastName], [PreferredFirstName]), "(NYC)"), "Phoenix", Append(Join(", ",[PreferredLastName], [PreferredFirstName]), "(PHX)") )
另请参阅:
如何使用 SelectUniqueValue 生成 samAccountName 属性的唯一值?
假设要结合使用 Workday 中的 FirstName 和 LastName 属性为 samAccountName 属性生成唯一值 。 下面是最初可使用的表达式:
SelectUniqueValue(
Replace(Mid(Replace(NormalizeDiacritics(StripSpaces(Join("", Mid([FirstName],1,1), [LastName]))), , "([\\/\\\\\\[\\]\\:\\;\\|\\=\\,\\+\\*\\?\\<\\>])", , "", , ), 1, 20), , "(\\.)*$", , "", , ),
Replace(Mid(Replace(NormalizeDiacritics(StripSpaces(Join("", Mid([FirstName],1,2), [LastName]))), , "([\\/\\\\\\[\\]\\:\\;\\|\\=\\,\\+\\*\\?\\<\\>])", , "", , ), 1, 20), , "(\\.)*$", , "", , ),
Replace(Mid(Replace(NormalizeDiacritics(StripSpaces(Join("", Mid([FirstName],1,3), [LastName]))), , "([\\/\\\\\\[\\]\\:\\;\\|\\=\\,\\+\\*\\?\\<\\>])", , "", , ), 1, 20), , "(\\.)*$", , "", , )
)
上述表达式的工作原理是:如果用户是 John Smith,它首先尝试生成 JSmith;如果 JSmith 已存在,它将生成 JoSmith;如果这也存在,则它将生成 JohSmith。 该表达式还确保所生成的值满足与 samAccountName 相关的长度限制和特殊字符限制。
另请参阅:
如何删除带音调符号的字符并将其转换为普通的英文字母?
使用函数 Normalize Diacritics 删除用户名字和姓氏中的特殊字符,同时为用户构建电子邮件地址或 CN 值。
故障排除提示
本部分提供具体指导,其中介绍如何使用 Microsoft Entra 预配日志和 Windows Server 事件查看器日志对 Workday 集成方面的预配问题进行故障排除。 它基于教程:针对自动用户帐户预配进行报告中介绍的一般性疑难解答步骤和概念进行编制
本部分涵盖了疑难解答的以下方面:
- 配置预配代理以发出事件查看器日志
- 设置 Windows 事件查看器来排查代理方面的问题
- 设置 Microsoft Entra 管理中心预配日志进行服务故障排除
- 了解 AD 用户帐户创建操作的日志
- 了解经理更新操作的日志
- 解决常见错误
配置预配代理以发出事件查看器日志
登录到部署有预配代理的 Windows Server 计算机
停止 Microsoft Entra Connect 预配代理服务。
创建原始配置文件的副本:C:\Program Files\Microsoft Azure AD Connect Provisioning Agent\AADConnectProvisioningAgent.exe.config。
将现有
<system.diagnostics>
部分替换为以下内容。- 侦听器配置 etw 向 EventViewer 日志发出消息
- 侦听器配置 textWriterListener 向 ProvAgentTrace.log 文件发送跟踪消息。 仅对与 textWriterListener 相关的行取消评论,以进行高级故障排除。
<system.diagnostics> <sources> <source name="AAD Connect Provisioning Agent"> <listeners> <add name="console"/> <add name="etw"/> <!-- <add name="textWriterListener"/> --> </listeners> </source> </sources> <sharedListeners> <add name="console" type="System.Diagnostics.ConsoleTraceListener" initializeData="false"/> <add name="etw" type="System.Diagnostics.EventLogTraceListener" initializeData="Azure AD Connect Provisioning Agent"> <filter type="System.Diagnostics.EventTypeFilter" initializeData="All"/> </add> <!-- <add name="textWriterListener" type="System.Diagnostics.TextWriterTraceListener" initializeData="C:/ProgramData/Microsoft/Azure AD Connect Provisioning Agent/Trace/ProvAgentTrace.log"/> --> </sharedListeners> </system.diagnostics>
启动 Microsoft Entra Connect 预配代理服务。
设置 Windows 事件查看器来排查代理方面的问题
登录到部署有预配代理的 Windows Server 计算机
打开“Windows Server 事件查看器”桌面应用。
选择“Windows 日志”>“应用程序”。
使用“筛选当前日志…”选项,以查看在源“Microsoft Entra Connect 预配代理”下记录的所有事件,然后通过指定筛选器“-5”来排除事件 ID 为“5”的事件,如下所示。
注意
事件 ID 5 将代理启动消息捕获到 Microsoft Entra 云服务,因此我们在分析日志文件时对其进行筛选。
单击“确定”,然后按“日期和时间”列对结果视图进行排序 。
设置 Microsoft Entra 管理中心预配日志进行服务故障排除
启动 Microsoft Entra 管理中心,并导航到 Workday 预配应用程序的“预配”部分。
使用“预配日志”页面上的“列”按钮,在视图中仅显示下述列(日期、活动、状态、状态原因)。 此配置可确保仅着重于与疑难解答相关的数据。
使用“目标”和“数据范围”查询参数来筛选视图 。
- 将“目标”查询参数设置为 Workday 工作人员对象的“工作人员 ID”或“员工 ID”。
- 将“日期范围”设置为要调查是否存在预配错误或问题的相应时间段。
了解 AD 用户帐户创建操作的日志
当检测到 Workday 中存在新员工时(假设员工 ID 为 21023),Microsoft Entra 预配服务会尝试为该员工创建一个新的 AD 用户帐户,并在此过程中创建 4 个预配日志记录,如下所示:
单击任意预配日志记录时,会打开“活动详细信息”页面。 下面是“活动详细信息”页面上显示的每个日志记录类型的相关内容。
Workday 导入记录:此日志记录显示从 Workday 提取的工作人员信息。 请使用日志记录的“其他详细信息”部分中的信息来排查从 Workday 提取数据时遇到的问题。 下面显示了一个示例记录,还显示了有关如何解释每个字段的指针。
ErrorCode : None // Use the error code captured here to troubleshoot Workday issues EventName : EntryImportAdd // For full sync, value is "EntryImportAdd" and for delta sync, value is "EntryImport" JoiningProperty : 21023 // Value of the Workday attribute that serves as the Matching ID (usually the Worker ID or Employee ID field) SourceAnchor : a071861412de4c2486eb10e5ae0834c3 // set to the WorkdayID (WID) associated with the record
AD 导入记录:此日志记录显示从 AD 中提取的帐户信息。 由于在进行初始用户创建时没有 AD 帐户,因此活动状态原因将指示未在 Active Directory 中找到具有匹配 ID 属性值的帐户。 请使用日志记录的“其他详细信息”部分中的信息来排查从 Workday 提取数据时遇到的问题。 下面显示了一个示例记录,还显示了有关如何解释每个字段的指针。
ErrorCode : None // Use the error code captured here to troubleshoot Workday issues EventName : EntryImportObjectNotFound // Implies that object wasn't found in AD JoiningProperty : 21023 // Value of the Workday attribute that serves as the Matching ID
要查找与此 AD 导入操作对应的预配代理日志记录,请打开 Windows 事件查看器日志,并使用“查找…”菜单选项来查找包含匹配 ID/联接属性值(在本例中为 21023)的日志条目。
查找“事件 ID = 9”的条目,它将提供代理用于检索 AD 帐户的 LDAP 搜索筛选器。 你可验证这是否是适合用于检索唯一用户条目的搜索筛选器。
后面紧跟“事件 ID = 2”的记录会捕获搜索操作的结果及返回状态(即是否返回任何结果)。
同步规则操作记录:此日志记录显示属性映射规则和已配置的范围筛选器的结果,还显示要用于处理传入 Workday 事件的预配操作。 请使用日志记录的“其他详细信息”部分中的信息来排查同步操作问题。 下面显示了一个示例记录,还显示了有关如何解释每个字段的指针。
ErrorCode : None // Use the error code captured here to troubleshoot sync issues EventName : EntrySynchronizationAdd // Implies that the object is added JoiningProperty : 21023 // Value of the Workday attribute that serves as the Matching ID SourceAnchor : a071861412de4c2486eb10e5ae0834c3 // set to the WorkdayID (WID) associated with the profile in Workday
如果属性映射表达式或传入的 Workday 数据存在问题(例如,所需属性的值为空或为 null),则此阶段将失败,且 ErrorCode 将提供失败详细信息。
AD 导出记录:此日志记录显示 AD 帐户创建操作的结果及在该过程中设置的属性值。 请使用日志记录的“其他详细信息”部分中的信息来排查帐户创建操作问题。 下面显示了一个示例记录,还显示了有关如何解释每个字段的指针。 在“其他详细信息”部分中,“EventName”设置为“EntryExportAdd”,“JoiningProperty”设置为 Matching ID 属性的值,“SourceAnchor”设置为与记录关联的 WorkdayID (WID),而“TargetAnchor”设置为新建用户的 AD“ObjectGuid”属性的值。
ErrorCode : None // Use the error code captured here to troubleshoot AD account creation issues EventName : EntryExportAdd // Implies that object is created JoiningProperty : 21023 // Value of the Workday attribute that serves as the Matching ID SourceAnchor : a071861412de4c2486eb10e5ae0834c3 // set to the WorkdayID (WID) associated with the profile in Workday TargetAnchor : aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb // set to the value of the AD "objectGuid" attribute of the new user
要查找与此 AD 导出操作对应的预配代理日志记录,请打开 Windows 事件查看器日志,并使用“查找…”菜单选项来查找包含匹配 ID/联接属性值(在本例中为 21023)的日志条目。
查找与“事件 ID = 2”的导出操作的时间戳对应的 HTTP POST 记录。 此记录包含预配服务发送到预配代理的属性值。
紧接在上述事件之后,应该还有一个事件,它捕获“创建 AD 帐户”操作的响应。 此事件返回在 AD 中新创建的 objectGuid,且它在预配服务中设置为 TargetAnchor 属性。
了解经理更新操作的日志
manager 属性是 AD 中的引用属性。 预配服务不会将 manager 属性设置为用户创建操作的一部分。 而是在为用户创建 AD 帐户之后,将 manager 属性设置为“更新”操作的一部分。 扩充上述示例,假设在 Workday 中激活了员工 ID 为“21451”的新员工,且新员工的经理 (21023) 已拥有 AD 帐户。 在该场景中,搜索用户 21451 的预配日志会显示 5 个条目。
前 4 条记录与在用户创建操作期间介绍的记录类似。 第 5 条记录是与 manager 属性更新相关的导出。 日志记录显示 AD 帐户经理更新操作的结果,该操作通过经理的 objectGuid 属性执行。
// Modified Properties
Name : manager
New Value : "aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb" // objectGuid of the user 21023
// Additional Details
ErrorCode : None // Use the error code captured here to troubleshoot AD account creation issues
EventName : EntryExportUpdate // Implies that object is created
JoiningProperty : 21451 // Value of the Workday attribute that serves as the Matching ID
SourceAnchor : 9603bf594b9901693f307815bf21870a // WorkdayID of the user
TargetAnchor : 43b668e7-1d73-401c-a00a-fed14d31a1a8 // objectGuid of the user 21451
解决常见错误
本部分介绍 Workday 用户预配方面的常见错误及其解决方法。 错误按如下分组:
预配代理错误
# | 错误场景 | 可能的原因 | 推荐的解决方案 |
---|---|---|---|
1. | 安装预配代理时出错,显示错误消息:服务“Microsoft Entra Connect Provisioning Agent”(AADConnectProvisioningAgent) 启动失败。请确保有足够的特权来启动系统。 | 如果尝试在域控制器上安装预配代理,而组策略阻止服务启动,通常就会显示此错误。 如果正在运行代理的旧版本,并且在启动新的安装项之前未卸载该旧版本,则也会看见此消息。 | 在非 DC 服务器上安装预配代理。 请务必在安装新代理之前卸载旧版本的代理。 |
2. | Windows 服务“Microsoft Entra Connect Provisioning Agent”处于“正在启动”状态,且未切换到“正在运行”状态。 | 在安装期间,代理向导会在服务器上创建一个本地帐户(NT 服务 AADConnectProvisioningAgent),这是用于启动服务的登录帐户。 如果 Windows Server 上的安全策略阻止本地帐户运行服务,则将遇到此错误。 | 请打开服务控制台。 右键单击 Windows 服务“Microsoft Entra Connect 预配代理”,然后在“登录”选项卡中指定域管理员的帐户来运行该服务。 重启服务。 |
3. | 在“连接 Active Directory”步骤中向 AD 域配置预配代理时,向导需要很长时间才能尝试加载 AD 架构且最终会超时。 | 如果由于防火墙问题导致向导无法连接 AD 域控制器服务器,则通常会显示此错误。 | 在“连接 Active Directory”向导屏幕上,当为 AD 域提供凭据时,有一个名为“选择域控制器优先级”的选项。 使用此选项可选择与代理服务器位于同一站点的域控制器,并确保防火墙规则均未阻止通信。 |
连接错误
如果预配服务无法连接到 Workday 或 Active Directory,则可能导致预配进入隔离状态。 请使用下表来排查连接问题。
# | 错误场景 | 可能的原因 | 推荐的解决方案 |
---|---|---|---|
1. | 单击“测试连接”时,会收到错误消息:连接到 Active Directory 时出错。请确保本地预配代理正在运行且已配置了正确的 Active Directory 域。 | 如果预配代理当前未运行或 Microsoft Entra ID 与预配代理之间有防火墙阻止通信,则通常会显示此错误。 如果未在代理向导中配置域,也可能会显示此错误。 | 请打开 Windows 服务器上的服务控制台来确定代理正在运行。 打开预配代理向导并确认向代理注册了正确的域。 |
2. | 预配作业在周末(周五至周六)进入隔离状态,且我们收到一封电子邮件通知,其中指出同步出错。 | 导致此错误的常见原因之一是所计划的 Workday 停机时间。 如果你在使用一个 Workday 实现租户,则请注意,Workday 安排了在周末(通常是从周五晚上到周六早上)对其实现租户停机,在此期间,Workday 预配应用可能会进入隔离状态,因而无法连接到 Workday。 一旦 Workday 实现租户重新上线,该应用即恢复正常状态。 在极少数情况下,如果因租户刷新而出现集成系统用户密码更改,或者帐户处于锁定或过期状态,则也可能看到此错误。 | 请咨询 Workday 管理员或集成合作伙伴,了解 Workday 何时安排停机时间,从而忽略停机期间出现的警报消息,并在 Workday 实例重新联机后确认其是否可用。 |
AD 用户帐户创建错误
# | 错误场景 | 可能的原因 | 推荐的解决方案 |
---|---|---|---|
1. | 预配日志中的导出操作失败,并显示消息错误: OperationsError-SvcErr: 出现操作错误。没有为目录服务配置高级引用。因此,目录服务无法向此林外的对象发出引用。 | 如果未正确设置 Active Directory 容器 OU,或者用于 parentDistinguishedName 的表达式映射存在问题,则通常会显示此错误。 | 请检查 Active Directory 容器 OU 参数是否有拼写错误。 如果在属性映射中使用 parentDistinguishedName,请确保它始终解析为 AD 域中的已知容器。 检查预配日志中的导出事件,查看所生成的值。 |
2. | 预配日志中的导出操作失败,并显示错误代码:SystemForCrossDomainIdentityManagementBadResponse 和消息“错误: ConstraintViolation-AtrErr: 请求中的值无效”。属性的值不在可接受的值范围内。\n错误详细信息:CONSTRAINT_ATT_TYPE - company。 | 虽然此错误特定于 company 属性,但 CN 等其他属性也可能出现此错误 。 由于 AD 强制架构约束而出现此错误。 默认情况下,AD 中的属性(例如 company 和 CN)的字符数上限为 64 个字符 。 如果来自 Workday 的值超过 64 个字符,则将出现此错误消息。 | 请检查预配日志中的导出事件,查看错误消息中报告的属性的值。 考虑使用 Mid 函数截断来自 Workday 的值,或者将映射更改为不具有类似长度约束的 AD 属性。 |
AD 用户帐户更新错误
在 AD 用户帐户的更新过程中,预配服务会从 Workday 和 AD 读取信息,运行属性映射规则并确定是否需要任何更改。 相应地,会触发更新事件。 如果上述任一步骤失败,都会记录到预配日志中。 请使用下表来排查常见的更新错误。
# | 错误场景 | 可能的原因 | 推荐的解决方案 |
---|---|---|---|
1. | 预配日志中的同步规则操作失败,并显示消息“EventName = EntrySynchronizationError and ErrorCode = EndpointUnavailable”。 | 如果因本地预配代理遇到处理错误而导致预配服务无法从 Active Directory 检索用户个人资料数据,则会显示此错误。 | 请检查预配代理事件查看器日志,查找指示读取操作问题的错误事件(按事件 ID 2 进行筛选)。 |
2. | AD 中某些用户的 AD 中的 manager 属性未更新。 | 最可能导致此错误的原因是,使用了范围规则且用户的经理不在范围内。 如果未在目标 AD 域中找到经理的匹配 ID 属性(例如 EmployeeID)或者它未设置为正确的值,则也可能会遇到此问题。 | 请查看范围筛选器并将经理用户添加到范围中。 请检查 AD 中经理的个人资料,以确保匹配的 ID 属性存在相应的值。 |
管理配置
此部分介绍如何进一步扩展、自定义和管理由 Workday 驱动的用户预配配置。 它涵盖以下主题:
自定义 Workday 用户属性列表
适用于 Active Directory 和 Microsoft Entra ID 的 Workday 预配应用都包含一个默认的 Workday 用户属性列表,可以从中进行选择。 但是,这些列表并不详尽。 Workday 支持数百个可能的用户属性,这些属性可能是 Workday 租户中的标准属性或唯一属性。
Microsoft Entra 预配服务支持自定义列表或 Workday 属性,以包含人力资源 API 的 Get_Workers 操作中公开的所有属性。
要执行此更改,必须使用 Workday Studio 来提取表示要使用的属性的 XPath 表达式,然后使用高级属性编辑器将其添加到预配配置。
检索 Workday 用户属性的 XPath 表达式:
下载并安装 Workday Studio。 需要使用 Workday 社区帐户才能访问安装程序。
从 Workday Web 服务目录下载特定于计划使用的 WWS API 版本的 Workday Human_Resources WSDL 文件
启动 Workday Studio。
在命令栏中,选择“Workday”>“在测试器中测试 Web 服务”选项。
选择“外部”,然后选择在步骤 2 中下载的 Human_Resources WSDL 文件。
将“位置”字段设置为
https://IMPL-CC.workday.com/ccx/service/TENANT/Human_Resources
,不过,请将“IMPL-CC”替换为实际实例类型,并将“TENANT”替换为实际租户名称。将“操作”设置为 Get_Workers
单击“请求/响应”窗格下面的“配置”链接设置 Workday 凭据。 选中“身份验证”,并输入 Workday 集成系统帐户的用户名和密码。 请务必将用户名格式设置为 name@tenant,并保留选中“WS-Security UsernameToken”选项。
选择“确定”。
在“请求”窗格中,粘贴以下 XML。 将“Employee_ID”设置为 Workday 租户中某个真实用户的员工 ID。 将“wd:version”设置为计划使用的 WWS 版本。 选择一个已填充想要提取的属性的用户。
<?xml version="1.0" encoding="UTF-8"?> <env:Envelope xmlns:env="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="https://www.w3.org/2001/XMLSchema"> <env:Body> <wd:Get_Workers_Request xmlns:wd="urn:com.workday/bsvc" wd:version="v21.1"> <wd:Request_References wd:Skip_Non_Existing_Instances="true"> <wd:Worker_Reference> <wd:ID wd:type="Employee_ID">21008</wd:ID> </wd:Worker_Reference> </wd:Request_References> <wd:Response_Group> <wd:Include_Reference>true</wd:Include_Reference> <wd:Include_Personal_Information>true</wd:Include_Personal_Information> <wd:Include_Employment_Information>true</wd:Include_Employment_Information> <wd:Include_Management_Chain_Data>true</wd:Include_Management_Chain_Data> <wd:Include_Organizations>true</wd:Include_Organizations> <wd:Include_Reference>true</wd:Include_Reference> <wd:Include_Transaction_Log_Data>true</wd:Include_Transaction_Log_Data> <wd:Include_Photo>true</wd:Include_Photo> <wd:Include_User_Account>true</wd:Include_User_Account> <wd:Include_Roles>true</wd:Include_Roles> </wd:Response_Group> </wd:Get_Workers_Request> </env:Body> </env:Envelope>
单击“发送请求”(绿色箭头)执行该命令。 如果成功,“响应”窗格中应会显示响应。 检查响应,确保其中包含输入的用户 ID 数据且不包含错误。
如果成功,请复制“响应”窗格中的 XML 并将其保存为 XML 文件。
在 Workday Studio 的命令栏中,选择“文件”>“打开文件...”,并打开已保存的 XML 文件。 此操作会在 Workday Studio XML 编辑器中打开该文件。
在文件树中,浏览“/env: Envelope > env: Body > wd:Get_Workers_Response > wd:Response_Data > wd: Worker”以找到用户的数据。
在“wd:Worker”下,找到要添加的属性并将其选中。
复制“文档路径”字段中选定属性的 XPath 表达式。
从复制的表达式中删除“/env:Envelope/env:Body/wd:Get_Workers_Response/wd:Response_Data/”前缀。
如果复制的表达式中的最后一项为节点(例如“/ wd:Birth_Date”),则在表达式的末尾追加“/text()”。 如果最后一项是一个属性(例如“/@wd: type”),则不需要执行此操作。
结果应类似于
wd:Worker/wd:Worker_Data/wd:Personal_Data/wd:Birth_Date/text()
。 此值是你复制并输入到 Microsoft Entra 管理中心的值。
将自定义 Workday 用户属性添加到预配配置:
启动 Microsoft Entra 管理中心,并根据本教程前面所述,导航到 Workday 预配应用程序的“预配”部分。
将“预配状态”设置为“关闭”,选择“保存”。 此步骤有助于确保更改仅在准备就绪时生效。
在“映射”下,选择“将 Workday 工作人员同步到本地 Active Directory”(或“将 Workday 工作人员同步到 Microsoft Entra ID)。
在下一屏幕中滚动到底部,选择“显示高级选项”。
选择“编辑 Workday 的属性列表”。
滚动到属性列表的底部查看输入字段。
对于“名称”,请输入属性的显示名称。
对于“类型”,请选择对应于属性的类型(最常用的选项是“字符串”)。
对于“API 表达式”,请输入从 Workday Studio 复制的 XPath 表达式。 示例:
wd:Worker/wd:Worker_Data/wd:Personal_Data/wd:Birth_Date/text()
选择“添加属性”。
选择上面的“保存”,然后在对话框中选择“是”。 如果“属性映射”屏幕仍然处于打开状态,请将其关闭。
返回“预配”主选项卡,再次选择“将 Workday 工作人员同步到本地 Active Directory”(或“将 Workday 工作人员同步到 Microsoft Entra ID”)。
选择“添加新映射”。
此时,新属性应会显示在“源属性”列表中。
根据需要添加新属性的映射。
完成后,请记得将“预配状态”改回“打开”并保存设置。
导出和导入配置
请参阅导出和导入预配配置一文
管理个人数据
Active Directory 的 Workday 预配解决方案要求在本地 Windows Server上安装预配代理;该代理会在 Windows 事件日志中创建日志,其中可能包含个人数据(具体取决于 Workday 到 AD 属性映射)。 为了遵守用户隐私义务,可通过设置 Windows 计划任务来清除事件日志,从而确保 48 小时之前的事件日志中不保留任何数据。
Microsoft Entra 预配服务属于 GDPR 的数据处理器类别。 该服务作为数据处理器管道,向关键合作伙伴和最终客户提供数据处理服务。 Microsoft Entra 预配服务不会生成用户数据,也无法独立控制收集哪些个人数据以及如何使用这些数据。 Microsoft Entra 预配服务基于现有企业数据进行数据检索、聚合、分析和报告。
注意
若要了解如何查看或删除个人数据,请在符合 GDPR 的 Windows 数据主体请求站点中查看 Microsoft 的指南。 有关 GDPR 的常规信息,请参阅 Microsoft 信任中心的 GDPR 部分和服务信任门户的 GDPR 部分。
在数据保留方面,Microsoft Entra 预配服务在 30 天之后不会生成报告、执行分析或提供见解。 因此,Microsoft Entra 预配服务不会存储、处理或保留超过 30 天的任何数据。 此设计符合 GDPR 法规要求、Microsoft 隐私符合性规定和 Microsoft Entra 数据保留策略。