漂泊雪狼的博客

思考,讨论,分享C#,JavaScript,.NET,Oracle,SQL Server……技术
posts - 43, comments - 206, trackbacks - 9, articles - 10
首先我们来了解一下什么是Active Directory。不用我描述,看以下网址,或在.net自带帮助文档里根据Active Directory关键字一搜,就什么都明白了。
http://developer.ccidnet.com/pub/article/c322_a28703_p2.html

接下来,我们来看看权限。你可以通过“网上邻居--整个网络--Directory--demain(你的域名)”你就可以看到所有关于域下的信息,粗一看就知道是怎么回事了。
需要告诉大家的:所有组织单位下的用户都在Users(容器)--Demain Users(组)中
用代码进行访问时,如果你是域管理员用户,则可以做任何操作,否则,只能查询用户属性。

private void SearchUser()
{
string domainName = "Domain";
string groupName = "Domain Users";
string dirmemName="";
//在Domain Users域用户里取得每个用户名
System.DirectoryServices.DirectoryEntry group = new System.DirectoryServices.DirectoryEntry("WinNT://" + domainName + "/" + groupName + ",group");
foreach(Object member in (IEnumerable)group.Invoke("Members"))
{
//根据很个用户生成如:"LDAP://OU=套装软体课,OU=系统开发部,OU=资讯服务处,OU=营运支援中心,OU=XX公司,DC=Domain,DC=com,DC=cn"
System.DirectoryServices.DirectoryEntry dirmem = new System.DirectoryServices.DirectoryEntry(member);
dirmemName=dirmem.Name;
string DomainName="Domain";
string FilterStr = "(sAMAccountname="+dirmemName+")";
System.DirectoryServices.DirectorySearcher FindMe = new System.DirectoryServices.DirectorySearcher(DomainName);
FindMe.Filter = FilterStr;
System.DirectoryServices.SearchResult FindRes = FindMe.FindOne();
System.DirectoryServices.DirectoryEntry MyUser = FindRes.GetDirectoryEntry();
string OUPath=MyUser.Parent.Path;
//找到该用户所在的LDAP:后,由域管理员登录,并取得该用户的所在属性。
string strFieldsValue="",strFields="";
System.DirectoryServices.DirectoryEntry myds=new System.DirectoryServices.DirectoryEntry(OUPath,"域管理员名","域管理员密码");
foreach(System.DirectoryServices.DirectoryEntry tempEntry in myds.Children)
{
if(tempEntry.SchemaClassName.ToString() == "user" && tempEntry.Properties["sAMAccountName"].Value.ToString().ToLower()==dirmemName)
{
foreach (string propertyName in tempEntry.Properties.PropertyNames )
{
string oneNode = propertyName + ": " +
entry.Properties[propertyName][0].ToString();
this.Textbox1.Text=oneNode;
}
}







public void AddUser(string strPath,string Username,string ChineseName)//strPath 增加用户至哪个组织单位如"LDAP://OU=XX公司,DC=Domain,DC=com"帐号、中文名{
try
{
string RootDSE;
//System.DirectoryServices.DirectorySearcher DSESearcher= new System.DirectoryServices.DirectorySearcher();
//RootDSE=DSESearcher.SearchRoot.Path;
//RootDSE="LDAP://DC=Domain,DC=com";
//RootDSE=RootDSE.Insert(7,"CN=Users,");
System.DirectoryServices.DirectoryEntry myDE = new System.DirectoryServices.DirectoryEntry(strPath); System.DirectoryServices.DirectoryEntries myEntries = myDE.Children;
// Create a new entry 'Sample' in the container.
string strname="CN="+ChineseName;
System.DirectoryServices.DirectoryEntry myDirectoryEntry = myEntries.Add(strname, "user");

//MessageBox.Show(myDirectoryEntry.SchemaClassName.ToString());
myDirectoryEntry.Properties["userPrincipalName"].Value=Username;
myDirectoryEntry.Properties["name"].Value=ChineseName;
myDirectoryEntry.Properties["samAccountName"].Value=Username;
myDirectoryEntry.Properties["userAccountControl"].Value =66048; //590336;
myDirectoryEntry.CommitChanges();
}



private void addOU(string strPath,string OUName)//增加组织到strPath组织单位下,组织名称
{
try
{
//String RootDSE;
//System.DirectoryServices.DirectorySearcher DSESearcher= new System.DirectoryServices.DirectorySearcher();
//RootDSE=DSESearcher.SearchRoot.Path;
//RootDSE="LDAP://OU=百意时尚广场,DC=Domain,DC=com";

System.DirectoryServices.DirectoryEntry myDE = new System.DirectoryServices.DirectoryEntry(strPath);
System.DirectoryServices.DirectoryEntries myEntries = myDE.Children;
string name="OU="+OUName;
System.DirectoryServices.DirectoryEntry myDirectoryEntry = myEntries.Add(name,"organizationalUnit");

myDirectoryEntry.Properties["name"].Value=OUName;
myDirectoryEntry.Properties["instanceType"].Value=4;
myDirectoryEntry.Properties["distinguishedName"].Value="OU="+OUName+",DC=Domain,DC=COM)";
myDirectoryEntry.Properties["objectCategory"].Value="CN=Organizational-Unit,CN=Schema,CN=Configuration,DC=sedep,DC=COM";
myDirectoryEntry.Properties["ou"].Value=OUName;
myDirectoryEntry.Properties["postalCode"].Value="777";

myDirectoryEntry.CommitChanges();
//UserMoveto("LDAP://OU="+OUName+",DC=sedep,DC=com",strPath);
}
catch(Exception RaiseErr)
{
MessageBox.Show (RaiseErr.Message);
}
}



private void ModifyUser()
{
try
{
string DomainName="Domain";
string FilterStr = "(sAMAccountname=karlluo)";
System.DirectoryServices.DirectorySearcher FindMe = new System.DirectoryServices.DirectorySearcher(DomainName);
FindMe.Filter = FilterStr;
System.DirectoryServices.SearchResult FindRes = FindMe.FindOne();
string tt=FindRes.Path;
System.DirectoryServices.DirectoryEntry MyUser = FindRes.GetDirectoryEntry();
string OUPath=MyUser.Parent.Path;

DirectoryEntry myds=new DirectoryEntry(OUPath,"域管理员名","域管理员密码");

foreach(System.DirectoryServices.DirectoryEntry tempEntry in myds.Children)
{
if(tempEntry.SchemaClassName.ToString() == "user")
{
if(tempEntry.Properties["sAMAccountName"].Value.ToString().ToLower()=="karlluo")
{
tempEntry.UsePropertyCache=true;
tempEntry.Properties["st"].Value="yyyyyyyyyyyyyyyy";
//newEntry.Properties["userPrincipalName"].Value="userID";
tempEntry.CommitChanges();
}
}
}
}
catch(Exception RaiseErr)
{
MessageBox.Show (RaiseErr.Message);
}

}


很多网友都需要AD同步的代码,现在共享一下,免得大家都找我要,AD同步示例

Feedback

#1楼    回复  引用    

2006-07-13 16:54 by 9527 [未注册用户]
楼主如何调试的,非要在2003 server系统上装vs2003才能调试吗?

#2楼 [楼主]   回复  引用  查看    

2006-07-13 18:07 by 漂泊雪狼      
只要安装了VS2003就可以调试的

我过去在xp下面安装的VS2003 也是可以调试

如果调试进程的话 xp和其他的系统附加的进程是不一样的!

#3楼    回复  引用  查看    

2006-07-13 19:24 by 高海东      
不错

#4楼    回复  引用  查看    

2006-07-13 21:07 by superstar      
不错,谁验证过了?

#5楼    回复  引用  查看    

2006-07-13 22:48 by oscar_expansion      
关注一下,请问楼主有修改AD Schema的例子不?呵呵,学习一下

#6楼    回复  引用    

2006-07-14 23:18 by 9527 [未注册用户]
请稳xp下如何调试?是不是要加入域?我试过了,好像不行啊

#7楼    回复  引用  查看    

2006-10-13 17:56 by 酒精和音乐      
编译都通不过

#8楼 [楼主]   回复  引用  查看    

2006-10-19 13:44 by 漂泊雪狼      
编译出什么错误?
你是否引用了命名空间?

#9楼    回复  引用    

2006-10-21 00:13 by walm [未注册用户]
有几个函数"}"括号都缺,SearchUser这个函数entry不知道在哪里定义的.
AddUser这个函数只有try{}没有catch{},````````````````

#10楼 [楼主]   回复  引用  查看    

2006-10-23 14:00 by 漂泊雪狼      
非常感谢walm 看这些代码如此仔细, 我这里只是一个示例,有些代码我没有粘贴上去,其实在开发应用的过程中,往往人人所需要做的AD操作,在细节方面都有些不同的,我的示例只是说明一些基本操作的方法,在实际情况中还是要根据实际情况修改代码,当然也可以将微软的那三个操作AD的主要类,自己拿来再次封装,以求多次使用。我手头有个到处AD中部门、人员、组等基本信息的实例代码,是上次项目中用到的,有需要的欢迎大家给我留言!

#11楼    回复  引用    

2006-11-07 10:52 by zhonghlning [未注册用户]
@漂泊雪狼
最近在研究ad,能给发一个嘛!zhonghlning@163.com
谢谢

#12楼    回复  引用  查看    

2007-01-12 08:52 by 野狼的天空      
研究ad,能给发一个,谢谢!hbyangyu@163.com

#13楼 [楼主]   回复  引用  查看    

2007-01-12 17:50 by 漂泊雪狼      
请问你要研究AD的那些操作,上面的例子基本涵盖AD的基本操作,我的应用可能和你们的不一样的!

#14楼    回复  引用  查看    

2007-01-17 15:47 by 野狼的天空      
你好!我想问能不能在from验证的方式下,得到使用asp.net程序的用户在域中的名字。

#15楼 [楼主]   回复  引用  查看    

2007-01-18 11:35 by 漂泊雪狼      
to 野狼的天空
你的意思说form验证和域验证同时对一个网站取作用,系统先要求输入域验证信息(如果没有登陆域的话),再要求输入窗体验证信息,我试过了,后者将前者覆盖了,只能取到form的验证信息,我觉得没有必要再去取域用户名了。

#16楼    回复  引用  查看    

2007-01-29 14:09 by 野狼的天空      
谢谢漂泊雪狼,我主要想是在域环境中,用户不必要进行验证,直接通过登录windows系统的域用户名,直接进入网站。

#17楼 [楼主]   回复  引用  查看    

2007-01-31 12:40 by 漂泊雪狼      
这样不能自动实现,你可以去掉网站的form验证,只要域验证通过就可以访问网站,或者写一段代码模拟用户登陆,而不用户输入用户名和密码,但是这时密码怎么输入?

#18楼    回复  引用    

2007-07-03 11:57 by peng [未注册用户]
研究ad,能给发一个,谢谢!
peng-py@163.com

#19楼 [楼主]   回复  引用  查看    

2007-07-03 14:42 by 漂泊雪狼      
我已经在上面提供下载了,你在上面下载就可以了!

#20楼    回复  引用    

2008-05-21 18:51 by QQ375315244 [未注册用户]
vs2005环境下编译不通过了!
- -!

#21楼    回复  引用    

2008-05-21 18:55 by QQ375315244 [未注册用户]
这个解决方案中的2个项目好想不能同时启动!
呵呵
我是菜鸟新学
望楼主给个同时启动的方法

#22楼    回复  引用    

2008-05-21 18:58 by QQ375315244 [未注册用户]
我说的是AD同步示例

标题  
姓名  
主页
Email (只有博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2007-07-03 14:40 编辑过


相关链接:
 
Search Engine Optimization