客户端的异常处理 
这个部分,我们将看看在客户端怎样处理从Web服务中所抛出的异常。为了说明这个做法,我们来创建一个新项目CategoriesServiceClient。一旦项目被创建,就在默认的表单上添加一个命令按钮,并命名为btnInvoke。因为需要在客户端引用Web服务,所以在项目CategoriesService中添加一个Web Reference。可以通过Project->Add Reference菜单选项来完成添加。然后修改命令按钮的Click事件,如下所示。 
  
private void btnInvoke_Click(object sender, System.EventArgs e) 
{ 
  try 
  { 
    Categories cat = new Categories(); 
MessageBox.Show(cat.AddCategories("<?xml version='1.0'?> 
       <Categories xmlns='http://tempuri.org/CategoriesNamespace'> 
       <Category><CategoryName>Test Category</CategoryName> 
       <CategoryDescription>Test Category Description 
       </CategoryDescription></Category></Categories>").ToString()); 
  } 
  catch(SoapException soapEx) 
  { 
    MessageBox.Show(soapEx.Code.ToString()); 
    //Load the Detail element of the SoaopException object 
    XmlDocument doc = new XmlDocument(); 
    doc.LoadXml(soapEx.Detail.OuterXml); 
    XmlNamespaceManager nsManager = new 
      XmlNamespaceManager(doc.NameTable); 
    // Add the namespace to the NamespaceManager 
    nsManager.AddNamespace("errorNS", 
      "http://tempuri.org/CategoriesService"); 
    XmlNode categoryNode = 
      doc.DocumentElement.SelectSingleNode("errorNS:Error", 
                                           nsManager); 
    string errorNumber =  
      categoryNode.SelectSingleNode("errorNS:ErrorNumber", 
                                    nsManager).InnerText; 
string errorMessage =  
  categoryNode.SelectSingleNode("errorNS:ErrorMessage", 
                                nsManager).InnerText; 
string errorSource =  
  categoryNode.SelectSingleNode("errorNS:ErrorSource", 
                                nsManager).InnerText; 
    MessageBox.Show("Error Number is" +  errorNumber); 
    MessageBox.Show("Error Message is" + errorMessage); 
    MessageBox.Show("Error Source is" + errorSource); 
  } 
  catch(Exception ex) 
  { 
    MessageBox.Show(ex.Message); 
  } 
} 
  
客户端需要处理Web服务所产生的异常。因为Web服务所产生的异常都是SoapException形式的,所以调用Web服务的客户应用程序的代码应该被包含在try...catch块中,并且第一个catch块应该具有捕捉SoapException的处理器。让我们大致看看以上所示的代码。 
首先创建一个Categories类的实例。然后传入所要求的XML字符串参数,调用Categories类的AddCategories方法。再后,我们让catch块处理Web服务所产生的异常。在这个代码块中,我们以消息提示框的方式显示异常的产生者。我们通过使用SoapException对象的Code属性来完成这个显示。如果异常是因为客户端的非法输入而产生的,那么Code属性被设置为Client。如果异常是因为Web服务代码(例如,据库服务器已经关闭)而产生的,则Code属性被设为Server。 
然后,我们把包含在SoapException对象的Detail元素中的XML数据导入到一个XmlDocument对象中。类似于Web服务的代码,这里同样利用XmlNamespaceManager对象把命名空间与XmlDocument对象关联在一起。之后,取出包含在不同元素中的值,并把它们赋给本地变量。最后,使用消息提示框显示本地变量的值。 
把它放在一起 
至此,我们已经完成了客户应用程序,现在让我们运行测试它。如果运行客户程序,它将显示一个消息框(具有true值),那么则表明categories详细信息已经成功保存到数据库中。现在,从输入的XML数据中删除<CategoryName>元素,运行客户程序。将会得到一个消息,表明异常的原因是客户程序,除此之外,还可以在SoapException对象中得到更多的异常信息。 
正如前面所提到的那样,如果Web服务失败是由于服务器端的一些问题引起的,那么SoapException对象的Code属性应该被设置为Server。为了测试这个,修改Web服务中的连接字符串为一个无效值。现在,如果运行客户程序,将会得到一个表明异常的原因是Server的消息(该例中的Web服务)。 
结论 本文中,我们已经了解到怎样使用SoapException对象来处理和传递异常给Web服务的客户端。我们还了解到SoapException对象是怎样利用SOAP fault编码(定义在SOAP规范中)来传递异常的。顺便,我们还讨论了处理客户端所产生的异常的步骤。虽然我们创建的应用的功能非常的简单,但是它给我们理解怎样抛出和处理Web服务中的异常提供了一个坚实的基础。 
 
  |