public void CreateWindowsGroup(String groupName, String groupDesc, int groupCtl)
{
String ladpRootPath = "LDAP://192.168.213.168/CN=Users,DC=pk1,DC=cctv,DC=com";
DirectoryEntry ladpRoot = new DirectoryEntry(ladpRootPath);
ladpRoot.Username = "XXXXX";
ladpRoot.Password = "XXXXX";
DirectoryEntry group = ladpRoot.Children.Add("CN=" + groupName, "group");
group.Properties["sAMAccountName"].Value = groupName;
group.Properties["description"].Value = groupDesc;
group.Properties["groupType"].Value = groupCtl;
group.CommitChanges();
group.Close();
}
上述代码用于在AD上创建一个用户组,值得注意的是如果你的程序是放在域控上面执行的,那么 ladpRoot.Username和ladpRoot.Password就不能赋值。另外ladpRootPath是ladp的路径写法,LDAP://192.168.213.168表示你要操作的主机地址, DC=pk1,DC=cctv,DC=com表示要操作的Windows域,CN=Users表示在windows域的主目录下的Users容器对象。方法参数groupCtl表示一些用户组的类别,包含组别和作用域两种含义,对于组别,分为通讯组和安全组,如果是安全组,值应该为-2147483648,否则为0.对于作用域,分为本地组、全局组和通用组,对应的值分别为0x4、0x2和0x8。groupCtl的值就应该 [组别值] | [作用域值]。
下面给出一些常用的用户操作代码:
修改用户组信息:
public void ModifyWindowsGroup(String groupName, String groupDesc, int groupCtl)
{
String ladpRootPath = "LDAP://192.168.213.168/CN=Users,DC=pk1,DC=cctv,DC=com";
DirectoryEntry ladpRoot = new DirectoryEntry(ladpRootPath);
ladpRoot.Username = "XXXXX";
ladpRoot.Password = "XXXXX";
DirectoryEntry group = ladpRoot.Children.Find("CN=" + groupName, "group");
group.Properties["description"].Value = groupDesc;
group.Properties["groupType"].Value = groupCtl;
group.CommitChanges();
group.Close();
}
删除用户组信息:
public void DeleteWindowsGroup(String groupName)
{
String ladpRootPath = "LDAP://192.168.213.168/CN=Users,DC=pk1,DC=cctv,DC=com";
DirectoryEntry ladpRoot = new DirectoryEntry(ladpRootPath);
ladpRoot.Username = "XXXXX";
ladpRoot.Password = "XXXXX";
DirectoryEntry group = ladpRoot.Children.Add("CN=" + groupName, "group");
group.DeleteTree();
group.CommitChanges();
group.Close();
}
分享到:
相关推荐
C#windows编程 (pdf)
C# 获取域所有信息,ou, 用户组,域用户,邮件地址。并模拟域目录结构。
c# window服务多线程实例
c#实现windows用户用户组管理AccountManagement
利用Windows10系统API实现的C#通知,可以实现使用C#推送通知到Win10通知栏,并可以和该通知进行交互。
使用C#获取WINDOWS系统的图标--DEMO
C#创建Windows服务(Windows Services) 实战之系统定时重启服务-程序开发
C#读取AD域里用户名或组
为《使用C# 完美实现多语言版本Windows应用程序》所附源代码,以便更好的学习C#窗体程序多语言版本的制作。 本源代码可以任何方式免费使用,但转载请注明出处 另:代码中仅处理资源,没有本地格式信息的处理,有这...
C# 开机启动服务(windows service) 本程序用ASP.NET C#开发,不针对系统版本限制。 本源码拿就来可以直接写您想要的服务,无需再改其它的代码,拿来主义是不是很好?例如订单服务。 本服务是100%源码,源码中包含: ...
C#创建、删除、修改Windows用户 指定用户分组 创建windows组
C#开发的简单的windows Explorer文件管理 能够查看文件夹,文件,运行文件及程序
C# 仿WINDOWS 计算器 C# 仿WINDOWS 计算器
利用 Windows API 32 中打印函数,对打印机进行发送打印任务、暂停、取消、获取打印任务、获取打印机列表、状态、纸张等信息。压缩包中包含4个平时收集的打印类,测试均可用。附含Windows API 函数 for Visual Basic...
使用c#创建windows窗口(基于api)
在WinForm下模拟windows用户访问域,语言为C#
c#类似windowxp界面c#类似windowxp界面
c#消息 windows消息参数大全
利用C# 部署Windows 服务,自动控制相关内容。 常用于程序的自动审核。
一个asp.net工程,demo页面上进行域用户的认证,创建,删除操作