加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 教程 > 正文

ASP XMLDom在服务器端操作XML文件的关键方法和实现

发布时间:2023-06-07 13:31:35 所属栏目:教程 来源:
导读:我曾经测试过不用数据库,把网站的会员信息,商品数据信息,交易信息,网站定制信息全部存放在三个xml文件中,运行结果十分正常,感觉上比数据库快多了,不过没有作测试,不能确定。

对于小数据量,xml文件在检索
我曾经测试过不用数据库,把网站的会员信息,商品数据信息,交易信息,网站定制信息全部存放在三个xml文件中,运行结果十分正常,感觉上比数据库快多了,不过没有作测试,不能确定。
 
对于小数据量,xml文件在检索更新上于ACCESS有很多优势。
 
我曾经测试过不用数据库,把网站的会员信息,商品数据信息,交易信息,网站定制信息全部存放在三个xml文件中,运行结果十分正常,感觉上比数据库快多了,不过没有作测试,不能确定。
 
下面说一下创建,查询,修改等对xml操作的主要方法
 
程序代码
 
NO.1--建立一个XML数据库data.xml
 
复制代码代码如下:
 
<?xml version="1.0"?>
 
<records>
 
<record>
 
<name>caca</name>
 
<qq>154222225</qq>
 
<email>root@3ney.com</email>
 
</record>
 
<records>
 
NO.2--建立对象CreateObject
 
建立data.xml的对象先
 
set xmldoc=server.createobjcet("microsoft.xmldom")
 
xmldoc.load(server.mappath("data.xml")
 
NO.3--选定节点SelectNode
 
你想操作哪个Node,必须定位到这个节点是不是,先看看这个data.xml有几个Node??
 
用一个递归函数搞定:
 
复制代码代码如下:
 
getnodes(xmldoc)
 
sub getnodes(node)
 
dim i
 
response.write("<br><b>NodeName:</b>"&node.nodename&"<br><b>NodeTypeString:</b>"&node.nodetypestring&"<br><b>NodeValue:</b>"&node.nodevalue&"<br><b>Text:</b>"&node.text&"<br><b>node.childnodes.length:</b>"&node.childnodes.length&"<p>")
 
if node.childnodes.length<>0 then
 
for i=0 to node.childnodes.length-1
 
getnodes(node.childnodes(i))
 
next
 
end if
 
end sub
 
用这个函数后,可以看到这个data.xml有10个Node
 
这些Node可以很简单的定位:
 
xmldoc
 
xmldoc.childnodes(0)
 
xmldoc.childnodes(1)
 
xmldoc.childnodes(1).childnodes(0)
 
xmldoc.childnodes(1).childnodes(0).childnodes(0)
 
xmldoc.childnodes(1).childnodes(0).childnodes(0).text
 
xmldoc.childnodes(1).childnodes(0).childnodes(1)
 
xmldoc.childnodes(1).childnodes(0).childnodes(1).text
 
xmldoc.childnodes(1).childnodes(0).childnodes(2)
 
xmldoc.childnodes(1).childnodes(0).childnodes(2).text
 
是不是定位很简单呀,还有个方法,比如定位<name>
 
xmldoc.selectsinglenode("//name")
 
NO.4--给节点赋值(修改节点的值)
 
学会了定位节点,利用其属性,就可以修改或者赋值了
 
例如,把<name>的值caca改为wawa
 
xmldoc.selectsinglenode("//name").text="wawa"
 
xmldoc.save(server.mappath("data.xml"))
 
搞定!
 
NO.5--创建新的节点CreatenewNode
 
用createelement或者createnode("","","")
 
例如:在record下新建个<age>,只需要一句就搞定:
 
xmldoc.selectsinglenode("//record").appendchild(xmldoc.createelement("<age>"))
 
给<age>赋值
 
xmldoc.selectsinglenode("//age").text="20"
 
xmldoc.save(server.mappath("data.xml"))
 
搞定!
 
NO.6--删除一个节点DeleteNode
 
你必须明确你想删除的这个节点的父节点,以及这个节点的特征
 
例如:删除<qq>节点
 
xmldoc.selectsinglenode("//record").removechild(xmldoc.selectsinglenode("//qq"))
 
例如:删除那个<name>=caca的<record>
 
xmldoc.selectsinglenode("//records").removechild(xmldoc.selectsinglenode("//record[name='caca']))
 
xmldoc.save(server.mappath("data.xml"))
 
搞定!
 
只有能熟练这6条code,用asp控制xml数据库,也就差不多了...
 
========================================================
 
'创建DOM对象
 
set objDom=server.CreateObject("MicroSoft.XMLDom")
 
'取得xml数据
 
'方法1 取得xml文件的xml数据
 
objDom.load("c:/test.xml")
 
'方法2 取得xml数据串的数据
 
objDom.loadxml("<people><man name="sd"/></people>")
 
'创建一个节点对象
 
Set Newnode=objDom.CreateElement("people")
 
'给这个节点赴值
 
Newnode.Text="人"
 
' 给这个节点添加属性
 
Set NewAttribute=objDom.CreateNode("attribute","name","")
 
NewAttribute.Text= "张三"
 
Newnode.SetAttributeNode NewAttribute
 
'给这个节点添加子节点
 
Set NewnodeChild=objDom.CreateElement("address")
 
Newnode.appendChild NewnodeChild
 
'保存这个节点对象
 
objDom.appendChild Newnode
 
objDom.save("c:/test.xml")
 
'查找一个节点对象
 
set objtofind=objdom.documentElement.SelectSingleNode("//people/man")
 
'取出这个节点对象的 节点名,节点值,某个属性值,和全部的xml
 
nodename=objtofind.nodename
 
nodevalue=objtofind.text
 
objtofind.GetAttributeNode("name").NodeValue '属性名为name的属性值
 
'取出一个属性节点对象
 
set objattrtofind=objdom.documentElement.SelectSingleNode("//people/man"). GetAttributeNode("name")
 
'取出这个节点的属性名,属性值
 
nodeattrname=objattrtofind.nodename
 
nodeattrvalue=objattrtofind.nodevalue
 
'删除一个节点对象
 
set objnode=objdom.documentElement.SelectSingleNode("//people/man") '要删除的节点
 
set objparentnode=objdom.documentElement.SelectSingleNode("//people") '要删除的节点的父节点
 
objparentnode.removeChild objnode
 
'取出一个节点的字节点集合
 
set objnodes=objdom.documentElement.SelectSingleNode("//people/man").ChildNodes
 
遍历这个集合
 
方法1
 
for each element in objnodes
 
response.write element.nodename 字节点名
 
response.write element.text 字节点值
 
next
 
方法2
 
domlength=objnodes.length
 
for i = 0 to domlength-1
 
response.write objnodes.childnodes(i).nodename 字节点名
 
response.write objnodes.childnodes(i).text 字节点值
 
next
 
'取出一个节点的属性集合
 
set objnodes=objdom.documentElement.SelectSingleNode("//people/man").GetAttributeNode("name").attributes
 
遍历这个集合
 
for each element in objnodes
 
response.write element.nodename 属性名
 
response.write element.nodevalue 属性值
 
next
 
等能够熟练的运用xmldom对象来操作xml文件了,就可以享受xmlhttp对象来实现asp下的许多功能了。
 
------------------------------------------------------------------------------------------
 
虽然asp只能简单的操作XML文件,可是对于一般程序开发者来说就已经足够。
 
之前,XML语言非常的少接触,后来慢慢的,发觉XML在存储数据上有很多的方便。虽然安全性不好(个人认为),可是对于一般的数据存储的确 是一个非常不错的选择。
 
今天因为在一个网站上需要用到XML,我在这里就做一些总结(后期将会用到):
 
==============
 
首先,先整理ASP读取XML文件
 
default.asp的代码
 
<%
 
dim node,i,nodecount
 
set Doc = CreateObject("Microsoft.XMLDOM")
 
Doc.async = false
 
Doc.load(Server.MapPath("data.xml"))
 
set root = Doc.documentElement
 
set nodeLis = root.childNodes
 
nodeCount = nodeLis.length
 
For i=1 to nodeCount
 
set node = nodeLis.nextNode()
 
set cost = node.attributes.getNamedItem("cost")
 
%>
 
第 <%=i%> 条记录:
 
<table width="50%" border="1">
 
<tr>
 
<td width="43" rowspan="2"><img src="<%=node.selectSingleNode("img").text%>"/></td>
 
<td width="46">书名</td>
 
<td width="48">出版社</td>
 
<td width="42">价格</td>
 
</tr>
 
<tr>
 
<td>
 
<%=node.selectSingleNode("name").text%>
 
</td>
 
<td>
 
<%=node.selectSingleNode("publisher").text%>
 
</td>
 
<td>
 
<%= cost.text%>
 
</td>
 
</tr>
 
</table>
 
<%
 
Next
 
%>
 
====================
 
接下来就是Data.xml数据内容
 
<?xml version="1.0" encoding="UTF-8"?>
 
<data>
 
<book cost="56">
 
<name>Dreamweaver</name>
 
<publisher>中国铁路出版社</publisher>
 
<img>img/dw.jpg</img>
 
</book>
 
<book cost="62">
 
<name>Flash</name>
 
<publisher>中国铁路出版社</publisher>
 
<img>img/flash.jpg</img>
 
</book>
 
<book cost="48">
 
<name>Firweorks</name>
 
<publisher>中国铁路出版社</publisher>
 
<img>img/fw.jpg</img>
 
</book>
 
</data>
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!