读者可以通过此实例,了解在ASP(Active Server Page)中如何操纵XML文件,并进行数据的各种处理,包括XML节点的建立、修改、删除和保存等等。文中涉及到的技术包括ASP,VBScript,DOM,XML和XSL等。
本文未对使用到的技术进行深入的理论介绍,因此,读者需要具备一定的相关知识,尤其是对ASP、XML和DOM应该有一定的了解。通读本文,并参考源代码,相信读者一定可以熟练地掌握XML编程。
一、程序说明
例程基于B/S结构,使用XML文件存储联系信息,然后通过一个VBScript写的Class,使用DOM,对XML文件中的联系信息进行各种操作。
例程提供的代码采用了统一的命名规范,主要包括:用三个字母的缩写说明变量类型,如数字类型——int,字符串类型——str,对象——obj,等等,虽然在ASP/VBScript中,不区分数据类型,但使用明显的数据类型说明,对程序的编写和维护还是很有意义的;使用有意义的变量名称,如XMLDocument对象,定义为objXmlDoc,等等,同样,这样做的也是为了更好地编写和维护程序。
此程序可以分为后台数据处理和前台界面表现两部分。
程序后台,使用VBScript编写了一个Class,这是在VBScript5.0版中提供的新特性。虽然这里Class的概念和真正的面向对象相去甚远,但是,在ASP中合理地使用Class,还是可以在一定程度上提高程序的运行效率和可维护性。
前台表现,使用XSL对XML文件中的数据进行了格式化,然后以HTML的形式输出到客户端,充分体现了XML技术带来的灵活性与可定制性。格式化的过程放在了服务器端,使用ASP程序完成,这样,客户端得到的是经过格式化之后的HTML信息,避免了兼容性问题的出现。
当然,程序对于具体的操作细节未作非常严格的检验,比如联系信息必填项的检查,但是,对于在ASP中使用DOM操作XML的有关部分,程序提供了完整的示例代码。
二、XML文件说明(persons.xml)
例程中使用到的XML文件结构十分简单,并且没有定义相关的Schema或者DTD,因为,对于此程序这是不必要的。当然,如果读者愿意自己定义一个的话,也不会对程序的运行产生影响。
程序的数据结构定义如下,Persons集合,它包含多个Person对象,每一个Person对象包括姓名Name、英文名Nick、手机Mobile、电话Tel、电子邮件Email、腾讯QQ和所在公司Company的属性。将以上定义对应到XML文件即,Persons为根节点,Person为Persons的子节点,Name、Nick、Mobile、Tel、Email、QQ和Company为Person的子节点。
这样,我们得到的XML文件内容如下:
<?xml version="1.0" encoding="gb2312"?> <Persons> <Person> <Name>小东</Name> <Nick>gwd</Nick> <Mobile>139XXXXXXXX</Mobile> <Tel>XXXXXXXX</Tel> <Email>gwd@chinaren.com</Email> <QQ>7066015</QQ> <Company>XXX</Company> <Person> </Person> |
读者需要注意<?xml version="1.0" encoding="gb2312"?>这一行,XML默认不支持中文,通过设置encoding属性,才可以使XML正确地显示中文。读者可以在IE5.0及以上版本的浏览器中访问此文件,它会以 树型结构把数据显示出来。
三、格式转换XSL文件说明(Persons.xsl)
例程中使用XSL对XMl数据进行格式化,并以HTML的形式返回到客户端。这个过程也可以放在客户端进行,但考虑到兼容性的问题,例程中采用了在服务器端通过ASP操纵DOM进行格式化的方法。
XSL文件的内容如下,
<?xml version="1.0" encoding="gb2312"?> function edit(intId) |
在服务器端的转换使用一个函数来完成,格式化成功,返回HTML字符串,格式化失败,打印出错误信息,如下,
'******************************************* strXmlFile = Server.MapPath(strXmlFile) Set objXml = Server.CreateObject("MSXML2.DOMDocument") objXML.Async = False Set objXsl = Nothing |
四、操作Xml数据的Cls_Person类说明(clsPerson.asp) '*************************************************** Class Cls_Person Private m_intId ' Id,对应Person节点在Persons集合中的位置 ' 类初始化 ' 类释放 '-----读写各个属性--------------------------- Public Property Get Id Public Property Let Id(intId) Public Property Get Name Public Property Let Name(strName) Public Property Get Nick Public Property Let Nick(strNick) Public Property Get Mobile Public Property Let Mobile(strMobile) Public Property Get Tel Public Property Let Tel(strTel) Public Property Get Email Public Property Let Email(strEmail) Public Property Get QQ Public Property Let QQ(strQQ) Public Property Get Company Public Property Let Company(strCompany) '----------------------------------------------- ' 获取错误信息 ' 私有方法,添加错误信息 ' 清除错误信息 ' 从Xml中读取指定节点的数据,并填充各个属性 ClearError If objXmlDoc Is Nothing Then If CStr(m_intId) = "-1" Then ' 选择并读取节点信息,赋予各个属性 ' 添加信息到XML文件中 ClearError If objXmlDoc Is Nothing Then ' 创建Person节点 ' 创建各个子节点 Set objNode = objXmlDoc.createElement("Nick") Set objNode = objXmlDoc.createElement("Mobile") Set objNode = objXmlDoc.createElement("Tel") Set objNode = objXmlDoc.createElement("Email") Set objNode = objXmlDoc.createElement("QQ") Set objNode = objXmlDoc.createElement("Company") Set objNode = Nothing On Error Resume Next ' 从XML文件中删除数据 ClearError If objXmlDoc Is Nothing Then If CStr(m_intId) = "-1" Then Set objNodeList = objXmlDoc.getElementsByTagName("Person") On Error Resume Next If Err.Number = 0 Then ' 修改XML文件中的数据 ClearError If objXmlDoc Is Nothing Then If CStr(m_intId) = "-1" Then Set objPersonList = objXmlDoc.getElementsByTagName("Person") Set objOldPerson = objPersonList(m_intId-1) ' 要修改的旧节点 Set objNewPerson = objXmlDoc.createElement("Person") ' 用来替换旧节点的新节点 Set objNode = objXmlDoc.createElement("Nick") Set objNode = objXmlDoc.createElement("Mobile") Set objNode = objXmlDoc.createElement("Tel") Set objNode = objXmlDoc.createElement("Email") Set objNode = objXmlDoc.createElement("QQ") Set objNode = objXmlDoc.createElement("Company") On Error Resume Next Set objOldPerson = Nothing If Err.Number = 0 Then End Class 五、程序首页(default.asp) <% Option Explicit <!--#include file="pub/funcxml.asp"--> 六、添加、修改和删除XML中的信息 <% Option Explicit <!--#include file="pub/funcxml.asp"--> <% Set objXml = Server.CreateObject("MSXML2.DOMDocument") 七、总结 <% Option Explicit <!--#include file="pub/funcxml.asp"--> 六、添加、修改和删除XML中的信息 <% Option Explicit <!--#include file="pub/funcxml.asp"--> <% Set objXml = Server.CreateObject("MSXML2.DOMDocument") 七、总结
Cls_Person类用来完成与联系人信息相关的各种操作,包括添加、修改和删除等等,它使用VBScript编写。Cls_Person包括Id、Name、Nick、Mobile、Tel、Email、QQ和Company属性,对应于XML文件中的Person节点。Cls_Person包括GetInfoFromXml、AddToXml、EditToXml和DeleteFormXml四个主要方法,分别完成获取信息,添加信息,修改信息和删除信息四个功能。
Cls_Person的具体实现如下,
' 说明:Person类
' 作者:gwd 2002-11-06
' 引用:pub/constpub.asp
'***************************************************
Private m_strName ' 姓名
Private m_strNick ' 英文名
Private m_strMobile ' 手机
Private m_strTel ' 电话
Private m_strEmail ' 电子邮件
Private m_strQQ ' QQ号
Private m_strCompany ' 所在公司
Private m_strError ' 出错信息
Private Sub Class_Initialize()
m_strError = ""
m_intId = -1
End Sub
Private Sub Class_Terminate()
m_strError = ""
End Sub
Id = m_intId
End Property
m_intId = intId
End Property
Name = m_strName
End Property
m_strName = strName
End Property
Nick = m_strNick
End Property
m_strNick = strNick
End Property
Mobile = m_strMobile
End Property
m_strMobile = strMobile
End Property
Tel = m_strTel
End Property
m_strTel = strTel
End Property
Email = m_strEmail
End Property
m_strEmail = strEmail
End Property
QQ = m_strQQ
End Property
m_strQQ = strQQ
End Property
Company = m_strCompany
End Property
m_strCompany = strCompany
End Property
Public Function GetLastError()
GetLastError = m_strError
End Function
Private Sub AddErr(strEcho)
m_strError = m_strError + "<Div CLASS=""alert"">" & strEcho & "</Div>"
End Sub
Public Function ClearError()
m_strError = ""
End Function
' 需要首先设置Id
Public Function GetInfoFromXml(objXmlDoc)
Dim objNodeList
Dim I
GetInfoFromXml = False
AddErr "Dom对象为空值"
Exit Function
End If
GetInfoFromXml = False
AddErr "未正确设置联系人对象的ID属性"
Exit Function
Else
I = m_intId - 1 ' 要读取得节点位置
End If
Set objNodeList = objXmlDoc.getElementsByTagName("Person")
If objNodeList.length - m_intId >= 0 Then
On Error Resume Next
m_strName = objNodeList(I).selectSingleNode("Name").Text
m_strNick = objNodeList(I).selectSingleNode("Nick").Text
m_strMobile = objNodeList(I).selectSingleNode("Mobile").Text
m_strTel = objNodeList(I).selectSingleNode("Tel").Text
m_strEmail = objNodeList(I).selectSingleNode("Email").Text
m_strQQ = objNodeList(I).selectSingleNode("QQ").Text
m_strCompany = objNodeList(I).selectSingleNode("Company").Text
GetInfoFromXml = True
Else
GetInfoFromXml = False
AddErr "获取联系信息发生错误"
Set objNodeList = Nothing
Exit Function
End If
Set objNodeList = Nothing
End Function
' 需要首先设置好要填充的属性
Public Function AddToXml(objXmlDoc)
Dim objPerson, objNode
AddToXml = False
AddErr "Dom对象为空值"
Exit Function
End If
Set objPerson = objXmlDoc.createElement("Person")
objXmlDoc.documentElement.appendChild objPerson
'-----------------------------------------------------
Set objNode = objXmlDoc.createElement("Name")
objNode.Text = m_strName
objPerson.appendChild objNode
objNode.Text = m_strNick
objPerson.appendChild objNode
objNode.Text = m_strMobile
objPerson.appendChild objNode
objNode.Text = m_strTel
objPerson.appendChild objNode
objNode.Text = m_strEmail
objPerson.appendChild objNode
objNode.Text = m_strQQ
objPerson.appendChild objNode
objNode.Text = m_strCompany
objPerson.appendChild objNode
'-----------------------------------------------------
Set objPerson = Nothing
objXmlDoc.save Server.MapPath(C_XMLFILE) '保存XML文件
If Err.Number = 0 Then
AddToXml = True
Else
AddToXml = False
AddErr Err.Description
End If
End Function
' 需要首先设置Id
Public Function DeleteFromXml(objXmlDoc)
Dim objNodeList, objNode
DeleteFromXml = False
AddErr "Dom对象为空值"
Exit Function
End If
DeleteFromXml = False
AddErr "未正确设置联系人对象的ID属性"
Exit Function
End If
If objNodeList.length - m_intId < 0 Then
DeleteFromXml = False
AddErr "未找到相应的联系人"
Set objNodeList = Nothing
Exit Function
End If
Set objNode = objXmlDoc.documentElement.removeChild(objNodeList(intId-1))
If objNode Is Nothing Then
DeleteFromXml = False
AddErr "删除联系人失败"
Set objNodeList = Nothing
Exit Function
Else
objXmlDoc.save Server.MapPath(C_XMLFILE)
End If
Set objNode = Nothing
Set objNodeList = Nothing
DeleteFromXml = True
Else
DeleteFromXml = False
AddErr Err.Description
End If
End Function
' 需要首先设置好Id
Public Function EditToXml(objXmlDoc)
Dim objPersonList, objOldPerson, objNewPerson, objNode
EditToXml = False
AddErr "Dom对象为空值"
Exit Function
End If
EditToXml = False
AddErr "未正确设置联系人对象的ID属性"
Exit Function
End If
If objPersonList.length - m_intId < 0 Then
DeleteFromXml = False
AddErr "未找到相应的联系人"
Set objPersonList = Nothing
Exit Function
End If
Set objNode = objXmlDoc.createElement("Name")
objNode.Text = m_strName
objNewPerson.appendChild objNode
objNode.Text = m_strNick
objNewPerson.appendChild objNode
objNode.Text = m_strMobile
objNewPerson.appendChild objNode
objNode.Text = m_strTel
objNewPerson.appendChild objNode
objNode.Text = m_strEmail
objNewPerson.appendChild objNode
objNode.Text = m_strQQ
objNewPerson.appendChild objNode
objNode.Text = m_strCompany
objNewPerson.appendChild objNode
' 进行替换
Set objNode = objXmlDoc.documentElement.replaceChild(objNewPerson, objOldPerson)
If objNode Is Nothing Then
EditToXml = False
AddErr "修改联系人失败"
Set objOldPerosn = Nothing
Set objNewPerson = Nothing
Set objPersonList = Nothing
Exit Function
Else
objXmlDoc.save Server.MapPath(C_XMLFILE)
End If
Set objNewPerson = Nothing
Set objPersonList = Nothing
EditToXml = True
Else
EditToXml = False
AddErr Err.Description
End If
End Function
调用相应的包含文件和公共函数,格式化XML文件,并进行显示。可以看到,页面Title是可定制的,公共的头部和尾部都做成了相应的包含文件。C_TITLE、C_XMLFILE和C_XSLFILE为公共常量,在constpub.asp文件中定义,至于它们的意义,相信读者可以很容易地明白。这里调用了上面定义的FormatXml函数。
'***********************************************
' 说明:通讯录
' 作者:gwd 2002-11-05
'***********************************************
%>
<!--#include file="pub/constpub.asp"-->
<HTML>
<HEAD>
<TITLE><% = C_TITLE %></TITLE>
<META HTTP-EQUIV="content-type" CONTENT="text/html;charset=GB2312"/>
<link rel="stylesheet" href="contact.css" type="text/css">
</HEAD>
<BODY>
<!--#include file="pub/header.asp"-->
<% = FormatXml(C_XMLFILE, C_XSLFILE) %>
<br>
<!--#include file="pub/footer.asp"-->
</BODY>
</HTML>
我们知道,在Cls_Person中已经定义了相应的方法,因此,在各个文件中,只需要调用对应的方法即可。添加信息的文件为add.asp,修改信息的文件为edit.asp,删除信息的文件为delete.asp,我们仅以add.asp文件为例进行说明。其中的CheckStrInput和CheckStrOutput函数,用来格式化用户的输入和输出字符串。
'***********************************************
' 说明:37080308通讯录
' 作者:gwd 2002-11-05
'***********************************************
%>
<!--#include file="pub/constpub.asp"-->
<!--#include file="pub/funcpub.asp"-->
<!--#include file="pub/class/clsPerson.asp"-->
Dim objXml, objPerson
Dim strErr
Set objPerson = New Cls_Person ' 生成Cls_Person对象
If Request.Form("btnOk") <> "" Then
If LoadXmlDoc(objXml, C_XMLFILE, False, strErr) Then ' 装载XML文件
' 给相应的属性赋值
objPerson.Name = CheckStrInput(Request.Form("txtName"))
objPerson.Nick = CheckStrInput(Request.Form("txtNick"))
objPerson.Mobile = CheckStrInput(Request.Form("txtMobile"))
objPerson.Tel = CheckStrInput(Request.Form("txtTel"))
objPerson.Email = CheckStrInput(Request.Form("txtEmail"))
objPerson.QQ = CheckStrInput(Request.Form("txtQQ"))
objPerson.Company = CheckStrInput(Request.Form("txtCompany"))
If Not objPerson.AddToXml(objXml) Then ' 调用Cls_Person类的AddToXml方法,添加数据
AddErr strErr, objPerson.GetLastError
Else
AddErr strErr, "添加成功"
Response.Write "<script language=""javascript"">opener.location.reload();</script>"
End If
End If
End If
Set objXml = Nothing
%>
<HTML>
<HEAD>
<TITLE><% = C_TITLE %></TITLE>
<META HTTP-EQUIV="content-type" CONTENT="text/html;charset=GB2312"/>
<link rel="stylesheet" href="contact.css" type="text/css">
<script language="javascript">
<!--
function CheckForm()
{
return true;
}
//-->
</script>
</HEAD>
<BODY>
<% = strErr %>
<div class="title">添加联系信息</div>
<form name="form1" method="post" action="add.asp" onsubmit="return CheckForm()">
<table align="center" width="100%" cellspacing="1" cellpadding="2" border="0" bgcolor="#666600">
<tr bgcolor="#ffffff">
<td width="25%" bgcolor="#e5e5e5" align="right"><b>姓名:</b></td>
<td width="75%"><input type="text" name="txtName" size="25" class="input" value="<%=CheckStrOutput(objPerson.Name)%>"></td>
</tr>
<tr bgcolor="#ffffff">
<td bgcolor="#e5e5e5" align="right"><b>英文名:</b></td>
<td><input type="text" name="txtNick" size="25" class="input" value="<%=CheckStrOutput(objPerson.Nick)%>"></td>
</tr>
<tr bgcolor="#ffffff">
<td bgcolor="#e5e5e5" align="right"><b>手机:</b></td>
<td><input type="text" name="txtMobile" size="25" class="input" value="<%=CheckStrOutput(objPerson.Mobile)%>"></td>
</tr>
<tr bgcolor="#ffffff">
<td bgcolor="#e5e5e5" align="right"><b>电话:</b></td>
<td><input type="text" name="txtTel" size="25" class="input" value="<%=CheckStrOutput(objPerson.Tel)%>"></td>
</tr>
<tr bgcolor="#ffffff">
<td bgcolor="#e5e5e5" align="right"><b>Email:</b></td>
<td><input type="text" name="txtEmail" size="25" class="input" value="<%=CheckStrOutput(objPerson.Email)%>"></td>
</tr>
<tr bgcolor="#ffffff">
<td bgcolor="#e5e5e5" align="right"><b>QQ:</b></td>
<td><input type="text" name="txtQQ" size="25" class="input" value="<%=CheckStrOutput(objPerson.QQ)%>"></td>
</tr>
<tr bgcolor="#ffffff">
<td bgcolor="#e5e5e5" align="right"><b>所在公司:</b></td>
<td><input type="text" name="txtCompany" size="25" class="input" value="<%=CheckStrOutput(objPerson.Company)%>"></td>
</tr>
</table>
<br>
<div align="center">
<input type="submit" name="btnOk" value="提交">
<input type="button" name="btnClose" value="关闭" onclick="javascript:return window.close();">
</div>
</form>
</BODY>
</HTML>
<%
Set objPerson = Nothing
%>
到此,我们的联系信息管理程序就大功告成了。怎么样,感觉如何,应该来说还是相当简单的吧。当然了,这个例程还有许多可以改进的地方,我这里也只不过是抛砖引玉,希望读者在掌握了XML编程之后,自行修改完善吧。
此例程已经在我本机(Windows Server 2000、IIS5.0和IE6.0)和网上进行了测试,都能够正常运行。
'***********************************************
' 说明:通讯录
' 作者:gwd 2002-11-05
'***********************************************
%>
<!--#include file="pub/constpub.asp"-->
<HTML>
<HEAD>
<TITLE><% = C_TITLE %></TITLE>
<META HTTP-EQUIV="content-type" CONTENT="text/html;charset=GB2312"/>
<link rel="stylesheet" href="contact.css" type="text/css">
</HEAD>
<BODY>
<!--#include file="pub/header.asp"-->
<% = FormatXml(C_XMLFILE, C_XSLFILE) %>
<br>
<!--#include file="pub/footer.asp"-->
</BODY>
</HTML>
我们知道,在Cls_Person中已经定义了相应的方法,因此,在各个文件中,只需要调用对应的方法即可。添加信息的文件为add.asp,修改信息的文件为edit.asp,删除信息的文件为delete.asp,我们仅以add.asp文件为例进行说明。其中的CheckStrInput和CheckStrOutput函数,用来格式化用户的输入和输出字符串。
'***********************************************
' 说明:37080308通讯录
' 作者:gwd 2002-11-05
'***********************************************
%>
<!--#include file="pub/constpub.asp"-->
<!--#include file="pub/funcpub.asp"-->
<!--#include file="pub/class/clsPerson.asp"-->
Dim objXml, objPerson
Dim strErr
Set objPerson = New Cls_Person ' 生成Cls_Person对象
If Request.Form("btnOk") <> "" Then
If LoadXmlDoc(objXml, C_XMLFILE, False, strErr) Then ' 装载XML文件
' 给相应的属性赋值
objPerson.Name = CheckStrInput(Request.Form("txtName"))
objPerson.Nick = CheckStrInput(Request.Form("txtNick"))
objPerson.Mobile = CheckStrInput(Request.Form("txtMobile"))
objPerson.Tel = CheckStrInput(Request.Form("txtTel"))
objPerson.Email = CheckStrInput(Request.Form("txtEmail"))
objPerson.QQ = CheckStrInput(Request.Form("txtQQ"))
objPerson.Company = CheckStrInput(Request.Form("txtCompany"))
If Not objPerson.AddToXml(objXml) Then ' 调用Cls_Person类的AddToXml方法,添加数据
AddErr strErr, objPerson.GetLastError
Else
AddErr strErr, "添加成功"
Response.Write "<script language=""javascript"">opener.location.reload();</script>"
End If
End If
End If
Set objXml = Nothing
%>
<HTML>
<HEAD>
<TITLE><% = C_TITLE %></TITLE>
<META HTTP-EQUIV="content-type" CONTENT="text/html;charset=GB2312"/>
<link rel="stylesheet" href="contact.css" type="text/css">
<script language="javascript">
<!--
function CheckForm()
{
return true;
}
//-->
</script>
</HEAD>
<BODY>
<% = strErr %>
<div class="title">添加联系信息</div>
<form name="form1" method="post" action="add.asp" onsubmit="return CheckForm()">
<table align="center" width="100%" cellspacing="1" cellpadding="2" border="0" bgcolor="#666600">
<tr bgcolor="#ffffff">
<td width="25%" bgcolor="#e5e5e5" align="right"><b>姓名:</b></td>
<td width="75%"><input type="text" name="txtName" size="25" class="input" value="<%=CheckStrOutput(objPerson.Name)%>"></td>
</tr>
<tr bgcolor="#ffffff">
<td bgcolor="#e5e5e5" align="right"><b>英文名:</b></td>
<td><input type="text" name="txtNick" size="25" class="input" value="<%=CheckStrOutput(objPerson.Nick)%>"></td>
</tr>
<tr bgcolor="#ffffff">
<td bgcolor="#e5e5e5" align="right"><b>手机:</b></td>
<td><input type="text" name="txtMobile" size="25" class="input" value="<%=CheckStrOutput(objPerson.Mobile)%>"></td>
</tr>
<tr bgcolor="#ffffff">
<td bgcolor="#e5e5e5" align="right"><b>电话:</b></td>
<td><input type="text" name="txtTel" size="25" class="input" value="<%=CheckStrOutput(objPerson.Tel)%>"></td>
</tr>
<tr bgcolor="#ffffff">
<td bgcolor="#e5e5e5" align="right"><b>Email:</b></td>
<td><input type="text" name="txtEmail" size="25" class="input" value="<%=CheckStrOutput(objPerson.Email)%>"></td>
</tr>
<tr bgcolor="#ffffff">
<td bgcolor="#e5e5e5" align="right"><b>QQ:</b></td>
<td><input type="text" name="txtQQ" size="25" class="input" value="<%=CheckStrOutput(objPerson.QQ)%>"></td>
</tr>
<tr bgcolor="#ffffff">
<td bgcolor="#e5e5e5" align="right"><b>所在公司:</b></td>
<td><input type="text" name="txtCompany" size="25" class="input" value="<%=CheckStrOutput(objPerson.Company)%>"></td>
</tr>
</table>
<br>
<div align="center">
<input type="submit" name="btnOk" value="提交">
<input type="button" name="btnClose" value="关闭" onclick="javascript:return window.close();">
</div>
</form>
</BODY>
</HTML>
<%
Set objPerson = Nothing
%>
到此,我们的联系信息管理程序就大功告成了。怎么样,感觉如何,应该来说还是相当简单的吧。当然了,这个例程还有许多可以改进的地方,我这里也只不过是抛砖引玉,希望读者在掌握了XML编程之后,自行修改完善吧。
此例程已经在我本机(Windows Server 2000、IIS5.0和IE6.0)和网上进行了测试,都能够正常运行。
'*************************************************** Class Cls_Person Private m_intId ' Id,对应Person节点在Persons集合中的位置 ' 类初始化 ' 类释放 '-----读写各个属性--------------------------- Public Property Get Id Public Property Let Id(intId) Public Property Get Name Public Property Let Name(strName) Public Property Get Nick Public Property Let Nick(strNick) Public Property Get Mobile Public Property Let Mobile(strMobile) Public Property Get Tel Public Property Let Tel(strTel) Public Property Get Email Public Property Let Email(strEmail) Public Property Get QQ Public Property Let QQ(strQQ) Public Property Get Company Public Property Let Company(strCompany) '----------------------------------------------- ' 获取错误信息 ' 私有方法,添加错误信息 ' 清除错误信息 ' 从Xml中读取指定节点的数据,并填充各个属性 ClearError If objXmlDoc Is Nothing Then If CStr(m_intId) = "-1" Then ' 选择并读取节点信息,赋予各个属性 ' 添加信息到XML文件中 ClearError If objXmlDoc Is Nothing Then ' 创建Person节点 ' 创建各个子节点 Set objNode = objXmlDoc.createElement("Nick") Set objNode = objXmlDoc.createElement("Mobile") Set objNode = objXmlDoc.createElement("Tel") Set objNode = objXmlDoc.createElement("Email") Set objNode = objXmlDoc.createElement("QQ") Set objNode = objXmlDoc.createElement("Company") Set objNode = Nothing On Error Resume Next ' 从XML文件中删除数据 ClearError If objXmlDoc Is Nothing Then If CStr(m_intId) = "-1" Then Set objNodeList = objXmlDoc.getElementsByTagName("Person") On Error Resume Next If Err.Number = 0 Then ' 修改XML文件中的数据 ClearError If objXmlDoc Is Nothing Then If CStr(m_intId) = "-1" Then Set objPersonList = objXmlDoc.getElementsByTagName("Person") Set objOldPerson = objPersonList(m_intId-1) ' 要修改的旧节点 Set objNewPerson = objXmlDoc.createElement("Person") ' 用来替换旧节点的新节点 Set objNode = objXmlDoc.createElement("Nick") Set objNode = objXmlDoc.createElement("Mobile") Set objNode = objXmlDoc.createElement("Tel") Set objNode = objXmlDoc.createElement("Email") Set objNode = objXmlDoc.createElement("QQ") Set objNode = objXmlDoc.createElement("Company") On Error Resume Next Set objOldPerson = Nothing If Err.Number = 0 Then End Class 五、程序首页(default.asp) <% Option Explicit <!--#include file="pub/funcxml.asp"--> 六、添加、修改和删除XML中的信息
七、总结
六、添加、修改和删除XML中的信息
七、总结 |