C#中WinForm采用Active Directory进行身份认证

本文介绍了ActiveDirectory作为Windows网络中的目录服务,在集中式管理和资源访问控制方面的作用。提供了AD认证的实现方法,包括通过用户名和密码进行登录验证,以及如何获取指定用户的组信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

关于Active Directory:
Active Directory是指Windows网络中的目录服务。它有两个作用:1.目录服务功能。2.集中式管理。我们这里就只讨论第二种作用,Active Directory可以集中管理对网络资源的访问,并允许用户只登陆一次就能访问在Active Directory上的所有资源。更重要的是,该技术还可以用来确保只有那些经过授权的用户或应用程序方可获准在具备安全保障的前提下针对相关资源实施访问调用。

好了,其它的我就暂时不写了,呵呵

下面说如何使用AD认证,首先可以根据用户名和密码来访问域
///<summary>
///验证AD用户是否登录成功
///</summary>
///<paramname="domain"></param>
///<paramname="userName"></param>
///<paramname="password"></param>
///<returns></returns>
publicboolTryAuthenticate(stringdomain,stringuserName,stringpassword)
{
boolisLogin=false;
try
{
DirectoryEntryentry
=newDirectoryEntry(string.Format("LDAP://{0}",domain),userName,password);
entry.RefreshCache();
isLogin
=true;
}
catch
{
isLogin
=false;
}
returnisLogin;
}

接下来,根据指定的用户名获取它所对应的Groups
///<summary>
///取userName所对应的Groups
///</summary>
///<paramname="userName"></param>
///<returns></returns>
publicList<string>GetADGroups(stringuserName)
{
List
<string>groups=newList<string>();
stringdomain=ConfigurationManager.AppSettings["Domain"];//配置文件里读取domain
stringadminUsername=ConfigurationManager.AppSettings["AdminUserName"];//配置文件里读取Admin的userName
stringadminPassword=ConfigurationManager.AppSettings["AdminPassword"];//配置文件里读取domain的Password
try
{
varentry
=newDirectoryEntry(string.Format("LDAP://{0}",domain),adminUsername,adminPassword);
entry.RefreshCache();

DirectorySearchersearch
=newDirectorySearcher(entry);

search.PropertiesToLoad.Add(
"memberof");
search.Filter
=string.Format("sAMAccountName={0}",userName);

SearchResultresult
=search.FindOne();
if(result!=null)
{
ResultPropertyValueCollectionc
=result.Properties["memberof"];
foreach(varainc)
{
stringtemp=a.ToString();
Matchmatch
=Regex.Match(temp,@"CN=/s*(?<g>/w*)/s*.");
groups.Add(match.Groups[
"g"].Value);
}
}
}
catch
{
}
returngroups;
}

下面有几个关于Active Directory的资源

Active Directory Users, Computers, and Groups

Howto: (Almost) Everything In Active Directory via C#

C# Asynchronous Multi-Threaded Active Directory User/Group Browser

Searching Active Directory for Users and Groups

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值