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

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

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

下面说如何使用AD认证,首先可以根据用户名和密码来访问域

ContractedBlock.gif ExpandedBlockStart.gif Code
        /// <summary>
        
/// 验证AD用户是否登录成功
        
/// </summary>
        
/// <param name="domain"></param>
        
/// <param name="userName"></param>
        
/// <param name="password"></param>
        
/// <returns></returns>
        public bool TryAuthenticate(string domain, string userName, string password)
        {
            
bool isLogin = false;
            
try
            {
                DirectoryEntry entry 
= new DirectoryEntry(string.Format("LDAP://{0}", domain), userName, password);
                entry.RefreshCache();
                isLogin 
= true;
            }
            
catch
            {
                isLogin 
= false;
            }
            
return isLogin;
        }

接下来,根据指定的用户名获取它所对应的Groups

ContractedBlock.gif ExpandedBlockStart.gif Code
        /// <summary>
        
/// 取 userName 所对应的 Groups
        
/// </summary>
        
/// <param name="userName"></param>
        
/// <returns></returns>
        public List<string> GetADGroups(string userName)
        {
            List
<string> groups = new List<string>();
            
string domain = ConfigurationManager.AppSettings["Domain"]; //配置文件里读取domain
            string adminUsername = ConfigurationManager.AppSettings["AdminUserName"];   //配置文件里读取Admin 的 userName
            string adminPassword = ConfigurationManager.AppSettings["AdminPassword"];   //配置文件里读取domain 的 Password
            try
            {
                var entry 
= new DirectoryEntry(string.Format("LDAP://{0}", domain), adminUsername, adminPassword);
                entry.RefreshCache();

                DirectorySearcher search 
= new DirectorySearcher(entry);

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

                SearchResult result 
= search.FindOne();
                
if (result != null)
                {
                    ResultPropertyValueCollection c 
= result.Properties["memberof"];
                    
foreach (var a in c)
                    {
                        
string temp = a.ToString();
                        Match match 
= Regex.Match(temp, @"CN=\s*(?<g>\w*)\s*.");
                        groups.Add(match.Groups[
"g"].Value);
                    }
                }
            }
            
catch
            {
            }
            
return groups;
        }

 

下面有几个关于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

转载于:https://www.cnblogs.com/chenjilv/archive/2009/02/20/1394590.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值