新客网WWW.XKER.COM:致力做中国最专业的网络学院!
学院: 操作系统 - 网络应用 - 服务器 - 网络安全 - 工具软件 - 办公软件 - Web开发 - 数据库 - 网页设计 - 图形图像 - 媒体动画 - 硬件学堂 - 存储频道 - QQ专区
您的位置:首页 > 网络学院 > 服务器 > web服务器 > 正文:用IE的Web服务建立ASP.NET应用程序

用IE的Web服务建立ASP.NET应用程序

新客网 XKER.COM 2007-01-13 来源: 收藏本文
在下面几行代码中,你把result对象的ID与callService方法返回的ID进行匹配:

//检查事件是否相同
if (iCallID != result.id)
return;
  接着检查error属性以确定在Web服务的执行过程中是否发生过错误。如果发生过错误,就在消息窗口中显示错误信息。如果没有错误,就处理返回的结果并把它们显示在HTML DIV标记中:

if(result.error)
{
  // 读取错误信息
  var faultCode = result.errorDetail.code;
  var faultString = result.errorDetail.string;
  alert("ERROR: Code = " + faultCode + ", Fault String=" + faultString); 
}
else
{
  //把结果值赋予本地变量
  objXMLNode = result.value;
  objXMLDoc = new ActiveXObject("Microsoft.XMLDOM");
  //把返回的XML字符串载入XMLDOM 对象
  objXMLDoc.loadXML(objXMLNode.xml); 
  //得到Employees节点的指针
  objEmployee = objXMLDoc.selectSingleNode("GetEmpDetailsByEmpIDResult").
   selectSingleNode("EmployeesRoot").selectSingleNode("Employees");
  //查看从服务器返回的employee 指针是否有效
  strHTML = "<font color=’#0000FF’>";
  if (objEmployee != null)
  {
   //动态生成HTML并添加到字符串的内容中
   strHTML += "<br><br>Employee ID :<b>" + 
    objEmployee.selectSingleNode("EmployeeID").text + 
   "</b><br><br>";
   strHTML += "Employee First Name :<b>" + 
    objEmployee.selectSingleNode("FirstName").text + 
   "</b><br><br>";
   strHTML += "Employee Last Name :<b>" + 
    objEmployee.selectSingleNode("LastName").text + 
   "</b><br><br>";
   strHTML += "Employee Title :<b>" + 
    objEmployee.selectSingleNode("Title").text + 
   "</b><br><br>";
   strHTML += "Employee Title :<b>" + 
    objEmployee.selectSingleNode("Title").text + 
   "</b><br><br>";
   strHTML += "Title Of Courtesy:<b>" + 
    objEmployee.selectSingleNode("TitleOfCourtesy").text + 
   "</b><br><br>";
   strHTML += "Postal Code:<b>" + 
    objEmployee.selectSingleNode("PostalCode").text + 
   "</b><br><br>"; 
  }
  else
  {
   strHTML += "<br><br><b>Employee 
   not found</b>";
  }
  strHTML += "</font>"
  //把动态生成的HTML赋予div标记
  divContents.innerHTML = strHTML;
  }
}
  在上面的例子中,你使用调用Web服务时指定的回调函数来处理Web服务返回的结果。还有一种办法,在定义DIV标记的时候你也可以指定一个回调函数(用这种方法把Web服务行为包含在页面中)。例如,在下面的代码中,你使用Web服务行为支持的onresult事件句柄指定了回调函数:

<div id="service" style="BEHAVIOR: url(webservice.htc)" 
onresult="DisplayResults()"></div>
  有了上面的定义后,你就可以在DisplayResults函数中处理Web服务返回的结果了。下面的代码演示了DisplayResults函数的一种实现示例:

function DisplayResults()

  //检查事件id是否相同
  if (iCallID != event.result.id) 
   return;
  if(event.result.error)
  {
   var faultCode = event.result.errorDetail.code;
   var faultString = event.result.errorDetail.string;
   alert("ERROR: Code = " + faultCode + ", Fault String=" + 
   faultString);
  }
  else
  {
   //显示结果值
   alert(event.result.value); 
  }
}
  在代码中你可以看到,我们使用event对象得到包含Web服务调用返回结果的result对象的指针。

  把代码放在一起

  如果使用浏览器查看上面的ASP.NET页面,你看到的输出类似下图。在employee文本框中输入一个有效的Employee ID并点击"Get Employee Details"调用远程Web服务。这种操作将导致对该Web服务的异步调用,并且该Web服务返回的结果将显示在Web页面的DIV元素中。


  我要再次重点强调,对于IE Web服务行为,需要IE 5或以上版本,因此如果你能够确定用户所使用的浏览器类型,这种技术就很适合用于企业内部网应用程序。

  结论

  在本文中,你看到了Web服务行为是如何提供一种从Web服务器向客户端浏览器传递信息的改进的解决方法的。使用Web服务行为调用远程Web方法简化了客户端的操作,使Web服务的使用更加有吸引力。我们同时看到Web服务行为是如何通过提供动态的交互操作Web页面,帮助我们提高了用户体验的。由于Web服务行为(webservice.htc文件)封装了使用SOAP调用远程Web服务所需要的代码,随着SOAP标准的演化,你可以独立地更新行为而不需要改变客户端脚本。

收藏】 【评论】 【推荐】 【投稿】 【打印】 【关闭
发表评论
要记得去论坛讨论,点击注册新会员匿名评论
评论内容:不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
阅读排行
随机推荐
实用信息推荐