分享
 
 
 

ADSI及其在WEB上的应用

王朝厨房·作者佚名  2007-01-02
窄屏简体版  字體: |||超大  

关键词:ADSI, Component, ASP, IIS

摘要:本文简要介绍了ADSI的特性,并通过实例介绍了如何利用ADSI开发基于WEB的Windows NT管理程序。

ADSI(Active Directory Service Interface)是Microsoft公司推出的允许客户以同一种界面管理不同目录服务的应用接口,它凭借强大的功能、简单的操作很快得到了广泛的应用。那么,ADSI究竟是怎样的东西,又如何利用呢?

首先,要明白什么是Active Directory(活动目录)。

Active Directory是未来的Windows2000中包含的一种目录服务,它扩展了以前版本Windows中目录服务的特性,并增加了一些全新的功能。活动目录具有安全、可分布、可分区、可复制等特点。它的设计方式可以很好地工作在各种设置上,不管是有几百个对象的单机还是由上百万个对象的服务器组。活动目录的新特性,是管理者和最终用户都可以操纵、管理大量的信息。

ADSI是一系列访问各种存储方式的数据的编程接口,在Microsoft目前的产品中,Windows NT4.0Server,Exchange,IIS,Site Server支持这种接口,在NT5.0种,ADSI将成为操作系统的接口并有可能取代注册表。采用这种借口,可以访问操作系统的所有配置信息。

ADSI认为任何数据都存为面向对象的数据库。通过ADSI,你不要掌握类似SQL一类的查询语言,与传统的数据库相比,对面向对象的数据库变成更加简单:在传统的数据库中,编程者必须理解一个对象怎样存储,在ADSI中,编程者只需知道对象的名字就可以访问它。

有很多种语言可以用来对ADSI进行编程,Visual Basic,VBScript,Java,C,C++都可以访问ADSI;由于Active Server Pages和VBScript与其结合的非常好,所以可以很容易写出访问目录服务的Internet应用程序。在Internet应用程序中,可以使用.asp文件在服务器上创建、操纵ADSI对象,并将其结果显示在Web页上。

来看一个简单的例子:

生成一个包含以下代码的ASP文件:

<%

strMachineName = "localhost" 'domain name

strObjectPath = "W3SVC/1" 'object name

'construct object location in IIS

strPath = "IIS://" & strMachineName & "/" & strObjectPath

Set IISObject = GetObject (strPath) 'connect to IIS metabase

%>

Name = "<%= IISObject.Name %>"<br>

Parent= "<%= IISObject.Parent %>"<br>

SchemaLocation = "<%= IISObject.Schema %>"<br>

Class = "<%= IISObject.Class %>"<br>

Guid = "<%= IISObject.Guid %>"<br>

ADSPath = "<%= IISObject.AdsPath %>"<br>

用浏览器浏览,输出结果如下:

Name = "1"

Parent= "IIS://localhost/W3SVC"

SchemaLocation = "IIS://localhost/schema/IIsWebServer"

Class = "IIsWebServer"

Guid = ""

ADSPath = "IIS://localhost/W3SVC/1"

注意,如果要运行上面这段代码,登录用户必须拥有IIS的管理员权限,为了使这种应用更具有普遍性,可以将程序做成组建安装在服务器上。这里,举一个例子,做一个通过对ADSI编程修改Windows NT用户口令的组件。

1、 打开VB5.0 或 6.0 ,新建一个ActiveX DLL

2、 将工程命名为 PasswordChanger,将缺省的类模块命名为 Main.

3、 将类Main的instancing属性改为:5-MultiUser

4、 将工程的线程模块设为:单元线程

5、 设定Microsoft Active DS Type Library(activeds.tlb)

6、 保存工程,将类命名为:Main.cls,工程命名为PasswordChanger.vbp.

7、 在类的代码窗口中加入以下代码:

Option Explicit

' 修改口令

Public Sub SetPassword(ByVal pstrUser As String, _

ByVal pstrOldPassword As String, ByVal pstrNewPassword _

As String, ByVal pstrConfirmPassword As String)

Dim adsUser As IADsUser

Dim strDialogText As String

On Error GoTo ChangePasswordErrorHandler

'用户名不能为空

If pstrUser <> vbNullString Then

'口令不能为空

If (Not (pstrOldPassword = vbNullString)) And _

(Not (pstrNewPassword = vbNullString)) Then

'两次必须输入相同的口令

If (Not (pstrNewPassword <> pstrConfirmPassword)) Then

' 设定 ADSI 提供者为 WindowsNT

' (domain 为主域)

Set adsUser = GetObject("WinNT://domain/" & pstrUser & ",user")

' 调用 ADSI ChangePassword 方法

adsUser.ChangePassword pstrOldPassword, pstrNewPassword

' 在浏览器端产生 HTML 对话框

strDialogText = """成功修改用户 " & pstrUser & _

" 的口令."""

Call CreateAlertMarkup(strDialogText)

Else

' 在浏览器端产生 HTML 对话框

strDialogText = """New/Confirm passwords are different."""

Call CreateAlertMarkup(strDialogText)

End If

Else

' 在浏览器端产生 HTML 对话框

strDialogText = """A value for Old/New passwords is required."""

Call CreateAlertMarkup(strDialogText)

End If

End If

Set adsUser = Nothing

Exit Sub

'**********

ChangePasswordErrorHandler:

'

'在浏览器端产生提示 “错误” 对话框

strDialogText = """用户 " & pstrUser & "的口令无法修改.\n\n"

strDialogText = strDialogText & "1. 新口令不能 " & _

"与以前的口令相同\n"

strDialogText = strDialogText & "2. 口令必须为 " & _

"8-14个字母长.\n"

strDialogText = strDialogText & "3. 口令至少要包含 " & _

"以下情况下的3个字母:\n"

strDialogText = strDialogText & " - 英文大写字母 (A-Z)\n"

strDialogText = strDialogText & " - 英文小写字亩 (a-z)\n"

strDialogText = strDialogText & " - 阿拉伯数字 (0-9)\n"

strDialogText = strDialogText & " - 其他字符" & _

" (例如标点符号)\n"

strDialogText = strDialogText & "4. 口令中不能包含你的用户名 " & _

"或你名字的任何一部分"""

Call CreateAlertMarkup(strDialogText)

End Sub

' 产生JavaScript警告对话框

Private Sub CreateAlertMarkup(pstrDialogText As String)

Dim strScriptingLanguage As String

strScriptingLanguage = """JavaScript"""

objResponse.Write vbCrLf

objResponse.Write ("<SCRIPT LANGUAGE=" & strScriptingLanguage & ">") & vbCrLf

objResponse.Write ("<!--") & vbCrLf

objResponse.Write ("{") & vbCrLf

objResponse.Write vbTab & ("window.alert(" & pstrDialogText & ");") & vbCrLf

objResponse.Write ("}") & vbCrLf

objResponse.Write ("-->") & vbCrLf

objResponse.Write ("</SCRIPT>") & vbCrLf

End Sub

8、 编译这段代码,生成PasswordChanger.dll.

9、 将产生的PasswordChanger.dll文件拷贝到 WINNT\SYSTEM32目录下。

10、 在dos提示符窗口中执行以下命令:

regsvr32 PasswordChanger.dll

系统将弹出一个对话框,告诉你登记组件成功。下面,需要写一个ASP文件来调用这个组件。

<html>

<head>

<%

' declare variables

Dim objReference

Dim strUser

Dim strOldPassword

Dim strNewPassword

Dim strConfirmNewPassword

' obtain form values

strUser = Request.Form("txtUser")

strOldPassword = Request.Form("txtOldPassword")

strNewPassword = Request.Form("txtNewPassword")

strConfirmNewPassword = Request.Form("txtConfirmNewPassword")

if strUser<>"" then

' create object

Set objReference = Server.CreateObject("PasswordChanger.Main")

' change the password

Call objReference.SetPassword(strUser,strOldPassword,strNewPassword,strConfirmNewPassword)

' release object reference

Set objReference = Nothing

end if

%>

<title>修改NT用户口令</title>

</head>

<body bgcolor="#ffffff">

<p><h2><font color=black face=Arial>修改NT用户口令</font></h2></p>

<form method="post" name="frmChangePassword" action="Changepwd.asp">

<table width=325 border="0">

<tr>

<td colSpan=2><b>

<font size=+1 face=Arial color=black>

User:

</font>

</b>

</td>

<td>

<input type=text size=20 name="txtUser"></td>

</tr>

<tr>

<td colSpan=2><b>

<font size=+1 color=black face=Arial>

Password:

</font>

</b>

</td>

<td><font>

<input type="password" name="txtOldPassword">

</font></td>

</tr>

<tr>

<td colSpan=2>

<b>

<font size=+1 color=black face=Arial>

New Password:

</font>

</b>

</td>

<td>

<font>

<input type="password" name="txtNewPassword">

</font>

</td>

</tr>

<tr>

<td colSpan=2><b>

<font size=+1 color=black face=Arial>

Confirm Password:

</font></b></td>

<td>

<input type="password" name="txtConfirmNewPassword">

</font></td>

</tr>

<tr>

<td colSpan=3></td>

</tr>

<tr>

<td colSpan=3>

<div align=center>

<font color=black face=Arial>

<INPUT id=txtChangePassword name=txtChangePassword

style="font-FAMILY: ; HEIGHT: 24px; WIDTH: 149px" type=submit value="Change Password">

</div>

</font>

</td>

</tr>

</table>

</form>

</body>

</html>

将此文件命名为changepwd.asp,在浏览器中运行,输入数据测试一下,怎么样,用户的口令是否已经修改了?

通过以上的例子可以看出,ADSI的确具有很强大的功能,操作也非常简单,结合ASP和VB,一定可以开发出功能更强大的Internet应用程序。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有