针对Active Directory进行身份验证

时间:2012-02-15 15:24:14

标签: c# .net c#-4.0 active-directory iprincipal

我做了一点谷歌搜索,我遇到了这个充满希望的代码

System.DirectoryServices.AccountManagement.PrincipalContext pc = new System.DirectoryServices.AccountManagement.PrincipalContext(ContextType.Domain, "YOURDOMAIN")
// validate the credentials 
bool validatedOnDomain = pc.ValidateCredentials(userName, tb.Text.ToString());

userName初始化为Windows登录名。它也是一个字符串 tb.Text.ToString()是用于输入密码的文本框

更新了代码并且它正常运行。谢谢大家

MSDN表示PrincipalContext可以使用两个参数

2 个答案:

答案 0 :(得分:5)

尝试找出这段代码..这在我的项目中完美运作。

public bool  ValidateUser(string varDomain, string varUserName, string varPwd)
    {
        Boolean isValidUser;
        using (PrincipalContext pc = new PrincipalContext(ContextType.Domain, varDomain))
        {
            isValidUser = pc.ValidateCredentials(varUserName, varPwd);
        }
        return isValidUser;

    }

答案 1 :(得分:3)

  using语句中使用的

类型必须可以隐式转换为'System.IDisposable'

表示您需要将代码更改为:

PrincipalContext pc = new PrincipalContext(ContextType.Domain, "YOURDOMAIN");

// validate the credentials 
bool validatedOnDomain = pc.ValidateCredentials(userName, tb.Text.ToString());

基本上它只是告诉您不能在PrincipalContext语句中使用using,因为PrincipalContext没有实现名为IDisposable的接口。

修改 正如marc_s在下面指出的那样,您使用的PrincipalContext不是正确的。它似乎存在于您自己的命名空间中。你应该使用System.DirectoryServices.AccountManagement中的那个。