两台服务器用XML连接数据

来源:互联网 发布:淘宝大码男装店 编辑:程序博客网 时间:2024/05/03 07:25
如果自己有两台服务器,如何将这两台服务器上的access数据库数据的互访。今天作了个远程的接口,以XML形式返回mdb中的数据。用的主要思想是通过recordset对象的save方法将数据填充到一个XML dom里,但是,这种方法产生的XML不够简洁,自动产生的XML包含了schema信息,它描述这个XML里允许有什么节点和属性以及采用何种数据类型,而且数据节点也增加了名称空间。schema信息在需要数据验证的地方或进行更复杂的处理或许很有用,但是,大多数情况下,我们使用的是瘦客户机,我们不需要schema信息。我们可以利用XSLT来分离出我们想要的信息,去掉多余的信息。 代码如下:<%'生成xsl样式str = chr(13)&chr(10)&chr(9)xslt="<?xml version=""1.0""?>" & chr(13)&chr(10) & "<xsl:stylesheet version=""1.0"""_&" xmlns:xsl=""http://www.w3.org/1999/XSL/Transform"""_&" xmlns:s=""uuid:BDC6E3F0-6DA3-11d1-A2A3-00AA00C14882"""_&" xmlns:dt=""uuid:C2F41010-65B3-11d1-A29F-00AA00C14882"""_&" xmlns:rs=""urn:schemas-microsoft-com:rowset"""_&" xmlns:z=""#RowsetSchema"">"& str_ 字串4& "<xsl:output omit-xml-declaration=""yes""/>"&str_& "<xsl:template match=""/"">"& str&chr(9)_& "<xsl:element name=""xml"">"& str&chr(9)&chr(9)_&"<xsl:for-each select=""/xml/rs:data/z:row"">"& str&chr(9)&chr(9)&chr(9)_&"<xsl:element name=""row"">"& str&chr(9)&chr(9)&chr(9)&chr(9)_&"<xsl:for-each select=""@*"">"& str&chr(9)&chr(9)&chr(9)&chr(9)&chr(9)_& "<xsl:element name=""{name()}"">"& str&chr(9)&chr(9)&chr(9)&chr(9)&chr(9)&chr(9)_& "<xsl:value-of select="".""/>"& str&chr(9)&chr(9)&chr(9)&chr(9)&chr(9)_&"</xsl:element>"& str&chr(9)&chr(9)&chr(9)&chr(9)_& "</xsl:for-each>"& str&chr(9)&chr(9)&chr(9)_& "</xsl:element>"& str&chr(9)&chr(9)_&"</xsl:for-each>"& str&chr(9)_ 字串2 &"</xsl:element>"& str_&"</xsl:template>"& chr(13)&chr(10)_&"</xsl:stylesheet>"'读取数据库curDir = Server.MapPath("data.mdb") set conn=server.createobject("adodb.connection")conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & curDirset rs=conn.Execute("select * from admins")Dim objXMLDOMSet objXMLDOM = Server.CreateObject("MSXML2.DOMDocument.3.0")'将recordset对象保存到dom里rs.save objXMLDOM, 1Set rs = NothingDim strCleanXML, objXMLDOM_XSLTSet objXMLDOM_XSLT = CreateObject("MSXML2.DOMDocument")objXMLDOM_XSLT.loadXml(xslt)'用xsl格式化数据strCleanXML = objXMLDOM.transformNode(objXMLDOM_XSLT)Set objXMLDOM = NothingSet objXMLDOM_XSLT = Nothing'输出数据Response.Write strCleanXML%>因为xml是跨平台的,所以呢不论是asp还是jsp或者客户端都可以通过该接口获得数据,然后用自己的样式来显示数据。比如,在客户端我们可以使用javascript操作xmlhttp来获得www.xxxx.com上某个mdb的数据: 字串3 <script language="javascript"> function req(){ var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); xmlhttp.Open("GET", "http://www.xxxx.com/mdb_inerface.asp", false); 'mdb_interface.asp既为放在www.xxxx.com上的mdb接口文件xmlhttp.Send(); alert(xmlhttp.responseText);} </script> </HEAD><body><input type="button" onclick="req();" value=" 获 取 " /></br>
原创粉丝点击