我正在使用WIF和ADFS 2.0构建MVC3 Web应用程序。我想要做的是为我的用户提供更改密码功能,他们将从这个Web应用程序更改他们的AD密码。由于我处于开发阶段,我必须能够从我的开发计算机(外部域)更改AD密码。稍后,权限将委派给运行具有足够访问权限的服务的用户。
我想做这个角色,而不输入用户名和密码,我似乎无法找到任何指向正确方向的资源。
有什么建议吗?
答案 0 :(得分:4)
WIF或AD FS中没有任何特定内容可用于更改用户密码。您必须使用System.DirectoryServices
命名空间中提供的标准AD功能。
以下是在AD中更改密码的示例代码:
internal UserPrincipal GetUser(string userName)
{
PrincipalContext principalContext = new PrincipalContext(ContextType.Domain, "YourADController",
"YourADContainer",
"ADAdminUser", "ADAdminPassword");
UserPrincipal user = UserPrincipal.FindByIdentity(principalContext, userName);
return user;
}
internal void ResetPassword(string userName, string newPassword)
{
try
{
//
// Update normal AD attributes
//
UserPrincipal user = GetUser(userName);
user.SetPassword(newPassword);
}
catch (PasswordException)
{
throw new Exception("Password does not meet complexity requirements");
}
}
internal void SetPassword(string userName, string oldPassword, string newPassword)
{
try
{
//
// Update normal AD attributes
//
UserPrincipal user = GetUser(userName);
user.ChangePassword(oldPassword, newPassword);
}
catch (PasswordException)
{
throw new Exception("Password does not meet complexity requirements");
}
}