asp

位置:IT落伍者 >> asp >> 浏览文章

利用XSL和ASP实现XML文档在线编辑


发布日期:2021年03月24日
 
利用XSL和ASP实现XML文档在线编辑

本文通过一个详细的例子来阐述了在线编辑XML文档数据的方法由于Netscape对XML的支持比较弱因此要实现跨平台的数据交换数据的处理必须在服务器端进行要编辑XML文档首先要做的事情就是怎样把这些数据提取并显示给访问者XSL为我们显示XML文件提供了一个很好的解决方案下面的例子就是利用XSL样式单把XML文档显示出来供用户进行编辑然后再把编辑后的数据提交到服务器在服务器端进行数据的更新这里采用ASP(Active Server Pages)来完成我们的任务

首先载入我们要进行编辑的XML文档利用微软的文档对象模型(Microsoft XMLDOM Object)和XSLXML文档就可以在服务器端转换成可以在客户端显示的HTML文件内容下面先看看我们使用的XML和XSL文件是什么样子的

XML文件UserDataxml

<?xml version= encoding=gb?>

<! edited with XMLSPY v rel U () by Dicky (AppleS Eden)

<UserInfo>

<Field ID=Name TabOrder=

<FieldValue>Dicky</FieldValue>

</Field>

<Field ID=Sex TabOrder=

<FieldValue>Male</FieldValue>

</Field>

<Field ID=UnitName TabOrder=

<FieldValue>ShangHai Ateam Company</FieldValue>

</Field>

<Field ID=Address TabOrder=

<FieldValue>ShangHaiZhongShan West Road #Room A</FieldValue>

</Field>

<Field ID=Tel TabOrder=

<FieldValue></FieldValue>

</Field>

<Field ID=EMail TabOrder=

<FieldValue>AppleBBS@GMailCom</FieldValue>

</Field>

</UserInfo>

XSL文件UserDataxsl

<?xml version= encoding=gb?>

<! edited with XMLSPY v rel U () by Dicky (AppleS Eden)

<xsl:stylesheet xmlns:xsl=xsl

<xsl:template match=/

<html>

<meta httpequiv=ContentType content=text/html; charset=gb/>

<body>

<form method=post action=EditUserDataasp

<h>Edit UserInfo</h

<table border= cellpadding=

<xsl:foreach select=UserInfo/Field

<tr>

<td>

<xsl:valueof select=@ID/>

</td>

<td>

<input type=text

<xsl:attribute name=ID><xsl:valueof select=@ID/></xsl:attribute>

<xsl:attribute name=Name><xsl:valueof select=@ID/></xsl:attribute>

<xsl:attribute name=Value><xsl:valueof select=FieldValue/></xsl:attribute>

</input>

</td>

</tr>

</xsl:foreach>

</table>

<br/>

<input type=submit id=btnSubmit name=btnSubmit value=Edit/>

</form>

</body>

</html>

</xsl:template>

</xsl:stylesheet>

XSL文件使用了XSLforeach元素的来遍历整个XML文件XML文件里每个field元素的id属性和HTML表单的文本输入框的idname相对应这样HTML表单的文本输入框就显示出了XML文件的元素值此文件负责XML文档在服务器端的转换以便能在各种浏览器上显示

下面是关键的程序它实现打开和更新XML文档的功能并根据表单的提交与否来决定是否进行更新它包含了两个函数loadXMLFile负责载入和转换要显示的XML文件updateXML函数负责更新XML文件

EditUserDataasp程序如下:

<%

定义函数 LoadXMLFile()接收二个参数

strXMLFile XML 文件的路径和文件名字

strXSLFilee XSL 文件的路径和文件名字

Function LoadXMLFile(strXMLFile strXSLFile)

Declare local variables

Dim objXML

Dim objXSL

实例化 XMLDOM 对象以便载入 XML 文件

Set objXML = ServerCreateObject(MicrosoftXMLDOM)

关掉文件异步载入模式

objXMLAsync = False

载入 XML 文件!

objXMLLoad(strXMLFile)

实例化 XMLDOM 对象以便载入 XSL 文件

Set objXSL = ServerCreateObject(MicrosoftXMLDOM)

关掉文件异步载入模式

objXSLAsync = False

载入 XSL 文件!

objXSLLoad(strXSLFile)

利用 XMLDOM 的 transformNode 方法把 XSL 样式表应用到 XML 文档然后输出到客户端

ResponseWrite(objXMLTransFormNode(objXSL))

End Function

函数 updateXML() 接收一个参数strXMLFile XML 文件的路径和文件名

Function UpdateXML(strXMLFile)

声明局部变量

Dim objDom

Dim objRoot

Dim objField

Dim x

实例化 XMLDOM 对象

Set objDOM = ServerCreateObject(MicrosoftXMLDOM)

关掉文件异步载入模式

objDomAsync = False

载入 XML 文件

objDomLoad strXMLFile

设定根元素

Set objRoot = objDomDocumentElement

遍历 FORM 集合并把提交的数据写入 XML 文件

For x = To RequestFormCount

检查提交的数据是否包含按钮如果是忽略此数据

If Instr(RequestFormKey(x)btn) = Then

按照 XSL 查询模式建立 objField 变量把表单的元素对应到 XML 文档里的相应元素[field_value]

Set objField = objRootSelectSingleNode(Field[@ID= & RequestFormKey(x) & ]/FieldValue)

把表单提交的数据和 XML 文档里的节点值对应起来

objFieldText = RequestForm(x)

End If

Next

保存编辑过的 XML 文件

objDomSave strXMLFile

释放所有对对象的引用

Set objDom = Nothing

Set objRoot = Nothing

Set objField = Nothing

调用 LoadXMLFile 函数把新编辑后的 XML 文件用 UpdatedUserDataxsl 样式单显示到客户端

LoadXMLFile strXMLFileServerMapPath(UpdatedUserDataxsl)

End Function

检查表单是否成功提交如提交更新 XML 文件否则转到编辑状态

If RequestForm(btnSubmit) = Then

LoadXMLFile ServerMapPath(UserDataxml)ServerMapPath(UserDataxsl)

Else

UpdateXML ServerMapPath(UserDataxml)

End If

%>

当表单提交成功后我们用UpdatedUserDataxsl来显示我们刚刚编辑的数据

UpdatedUserDataxsl如下:

<?xml version= encoding=gb?>

<! edited with XMLSPY v rel U () by Dicky (AppleS Eden)

<xsl:stylesheet xmlns:xsl=xsl

<xsl:template match=/

<html>

<meta httpequiv=ContentType content=text/html; charset=gb/>

<body>

<h>Updated UserInfo</h

<table border= cellpadding=

<xsl:foreach select=UserInfo/Field

<tr>

<td>

<xsl:valueof select=@ID/>

</td>

<td>

<xsl:valueof select=FieldValue/>

</td>

</tr>

</xsl:foreach>

</table>

<form>

<input type=button value=Go Back onclick=historygo()/>

</form>

</body>

</html>

</xsl:template>

</xsl:stylesheet>

以上只是XML跨平台应用的一个简单的例子结合具体的需求我们可以编写功能更强大的程序来完成我们更负杂的工作所有程序在Windows En+IIS +IE+MSXMLDll环境下调试通过               

上一篇:人文的ASP开发基础入门之简介

下一篇:asp不同子目录绑不同域名