由于经常有人问及此方面的问题所以我将整理出来的代码放到这里,大家参考一下:
使用前请添加com引用:active ds type library
一下代码在vb.net下编译通过
function domainpassword() as string
dim info as new activeds.adsysteminfoclass()
dim retdomain as string
retdomain = havedomainname(info.domaindnsname)
dim ouname as string = "users "
call getuser(retdomain, "administrator ", ouname, " ", " ")
end function
private sub getuser(byval strdomain as string, byval struser as string, byval organizationname as string, byval oldpasswd as string, byval newpasswd as string)
dim user as activeds.iadsuser
try
user = getobject( "ldap://cn= " & struser & ", " & organizationname & ", " & strdomain)
user.changepassword(oldpasswd, newpasswd)
catch ex as exception
response.write( " <script >alert('更改用户密码时发生错误( " & ex.source & "): " & ex.message & "') </script > ")
response.end()
end try
end sub
function havedomainname(byval strdomainname as string)
dim a(), b, d as string, i, e as integer
a = split(strdomainname, ". ", -1, 1)
e = ubound(a)
for i = 0 to e
if i < > e then
b = a(i)
d = d & "dc= " & a(i) & ", "
else
d = d & "dc= " & a(i)
end if
next
havedomainname = d
end function
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器