修改AD用户属性(例如电话号码、描述等)是AD管理员一项常见的基本工作,简单却十分繁琐,特别是在对大批量用户属性进行修改的情况下,工作量大且又是重复性的工作,若单个依次进行修改,效率低下,往往为人们所抱怨。有没有一种方便快捷、切能批量进行AD用户属性修改的方法呢?对此,本文作以下分享。(本文以批量修改AD用户电话号码属性为例来进行说明)
新建.txt文档,输入下述内容,并将此文档另存为chang.vbs文件。
Dim objInfo Const ADS_SCOPE_SUBTREE = 2 Set fso = CreateObject("Scripting.FileSystemObject") Set objFile = fso.OpenTextFile("Userinfo.csv") Set objConnection = CreateObject("ADODB.Connection") Set objCommand = CreateObject("ADODB.Command") objConnection.Provider = "ADsDSOObject" objConnection.Open "Active Directory Provider" Set objCommand.ActiveConnection = objConnection objCommand.Properties("Page Size") = 1000 objCommand.Properties("Searchscope") = ADS_SCOPE_SUBTREE Do On Error Resume Next objInfo = Split(objfile.ReadLine,",") strDN = FindUserDN(objInfo(0)) Set objUser = GetObject("LDAP://" & strDN) objUser.Put "mobile",objInfo(1) objUser.SetInfo If Err.Number <> 0 Then WScript.Echo "Error:" & objInfo(0) & "," & objInfo(1) End If strDN = "" Loop Until objfile.AtEndOfStream = True objfile.Close WScript.Echo "Done!" Function FindUserDN(strUserDisplayName) objCommand.CommandText = _ "SELECT distinguishedName FROM 'LDAP://OU=test,DC=contoso,DC=com' WHERE objectCategory='user' " & _ "AND displayname = '" & strUserDisplayName & "'" Set objRecordSet = objCommand.Execute objRecordSet.MoveFirst Do Until objRecordSet.EOF arrDN = objRecordSet.Fields("distinguishedName").Value If IsArray(arrDN) = True Then WScript.Echo strUserDisplayName FindUserDN = arrDN(0) Else FindUserDN = arrDN End if objRecordSet.MoveNext Loop If Err.Number <> 0 Then WScript.Echo Err.mobile & ":" & strUserDisplayName Err.Clear End If End Function
创建名为Userinfo.csv文件,文件内容根据实际需要,输入显示名称和用户的新电话号码,如下图所示:
将chang.vbs脚本和Userinfo.csv放到同一目录,双击chang.vbs脚本。待chang.vbs脚本运行成功即可实现OU=temp,DC=contoso,DC=com下用户IT001、IT002、IT003、IT004、IT005用户号码的更改,如下图所示:
本文所述只是以修改AD用户电话号码为例,若要实现不同OU下用户其他属性的修改,可根据需要对此脚本做相应调整:
1、修改用户属性项目,可对以下脚本内容进行调整:
Set objUser = GetObject("LDAP://" & strDN) objUser.Put "mobile",objInfo(1) objUser.SetInfo
2、针对不同OU下的用户可对以下脚本内容进行
'LDAP://OU=test,DC=contoso, DC=com' WHERE objectCategory='user' " & _ "AND displayname = '" & strUserDisplayName & "'"
自由广告区 |
分类导航 |
邮件新闻资讯: IT业界 | 邮件服务器 | 邮件趣闻 | 移动电邮 电子邮箱 | 反垃圾邮件|邮件客户端|网络安全 行业数据 | 邮件人物 | 网站公告 | 行业法规 网络技术: 邮件原理 | 网络协议 | 网络管理 | 传输介质 线路接入 | 路由接口 | 邮件存储 | 华为3Com CISCO技术 | 网络与服务器硬件 操作系统: Windows 9X | Linux&Uinx | Windows NT Windows Vista | FreeBSD | 其它操作系统 邮件服务器: 程序与开发 | Exchange | Qmail | Postfix Sendmail | MDaemon | Domino | Foxmail KerioMail | JavaMail | Winwebmail |James Merak&VisNetic | CMailServer | WinMail 金笛邮件系统 | 其它 | 反垃圾邮件: 综述| 客户端反垃圾邮件|服务器端反垃圾邮件 邮件客户端软件: Outlook | Foxmail | DreamMail| KooMail The bat | 雷鸟 | Eudora |Becky! |Pegasus IncrediMail |其它 电子邮箱: 个人邮箱 | 企业邮箱 |Gmail 移动电子邮件:服务器 | 客户端 | 技术前沿 邮件网络安全: 软件漏洞 | 安全知识 | 病毒公告 |防火墙 攻防技术 | 病毒查杀| ISA | 数字签名 邮件营销: Email营销 | 网络营销 | 营销技巧 |营销案例 邮件人才:招聘 | 职场 | 培训 | 指南 | 职场 解决方案: 邮件系统|反垃圾邮件 |安全 |移动电邮 |招标 产品评测: 邮件系统 |反垃圾邮件 |邮箱 |安全 |客户端 |