通过Web服务外置XML,将Web服务用作数据源,Web服务传递的内容是XML,将由Web服务返回的XML文档,以便可以将它加载到客户机上的XML分析器。
与上一个例子不同的地方在于数据访问组件是一个以Web服务形式实现的中间层,提供一个GetCustomers方法检索数据库中的数据,而且通过HTTP以标准的SOAP提供给客户机。
1.具体实现(代码仅供参考)
中间层 customer-data.asmx 实现Web服务
<%@WebService Language="C#" Class="Customer"%>
using System;
using System.Data;
using System.Web.Services; //导入Web服务命名空间
using System.Configuration;
[WebService(Description="Customer Service",Namespace="http://127.0.0.1/webservices/4923/customer")]
public class CustomerOrders
{
[WebMethod] public DataSet GetCustomers(String strCustID, String strCustName) //使用[WebMethod]特性表明GetCustomers方法通过Web服务可用,没有声明[WebMethod]特性的公共函数对客户机通过Web服务是不可用的。
{
//根据客户ID或客户姓名检索数据并返回DataSet
}
}
表示层:
(1)使用Web服务行为组件(webservices.htc),将其用于IE中来处理Web服务。关于webservices.htc的介绍及下载可到 http://msdn.microsoft.com/workshop/author/webservice/webservice.asp
<div style="behavior:url(../../global/webservice.htc)" id="htcWService">
View Customer - Select Customer
</div>
(2)用javascript声明一个全局变量保存MSXML分析起实例,创建一个openWebService函数打开Web服务 一旦webservice.htc行为插入页面,就可以使用它来访问Web服务
<body onload="openWebService()">
var objXMLData;
function openWebService() {
htcWService.useService("customer-data.asmx?WSDL","CustData"); //使用行为的useService方法打开Web Service,通过加载服务器的WSDL文档做到用户能够通过WSDL追加到查询字符串来制定它,同时提供一个“友好名称”CustData,将在代码中使用它来引用Web服务
var iCallID = htcWService.CustData.callService(dataLoaded, "GetCustomers", "", ""); //指定callService方法所需的参数:事件处理程序名,调用的方法名以及此方法的参数,为了得到所有的客户,使用了2个空字符串作为参数
}
function dataLoaded(objResult) {
if(objResult.error) { //检查是否出错
var strErrorCode = objResult.errorDetail.code;
var strErrorMsg = objResult.errorDetail.string;
var strErrorRaw = objResult.errorDetail.raw;
}
else { //如果没有出错,则将返回的数据转换成MSXML分析器的一个实例
try {
objXMLData = new ActiveXObject('MSXML2.FreeThreadedDOMDocument');
}
catch(e) {}
if (objXMLData == null) {
return;
}
objXMLData.onreadystatechange = changeFunction;
objXMLData.validateOnParse = true;
objXMLData.async = true;
objXMLData.loadXML(objResult.raw.xml); //从Web服务加载SOAP文档
}
}
function changeFunction()参考上个例子
(3)查找并显示顾客详细资料:参考上个例子