4 Web服务中的异常处理

【4 Web服务中的异常处理】客户端的异常处理
这个部分,我们将看看在客户端怎样处理从Web服务中所抛出的异常 。为了说明这个做法,我们来创建一个新项目CategoriesServiceClient 。一旦项目被创建,就在默认的表单上添加一个命令按钮,并命名为btnInvoke 。因为需要在客户端引用Web服务,所以在项目CategoriesService中添加一个WebReference 。可以通过Project->AddReference菜单选项来完成添加 。然后修改命令按钮的Click事件,如下所示 。
privatevoidbtnInvoke_Click(objectsender,System.EventArgse)
{
try
{
Categoriescat=newCategories();
MessageBox.Show(cat.AddCategories("
TestCategory
TestCategoryDescription
").ToString());
}
catch(SoapExceptionsoapEx)
{
MessageBox.Show(soapEx.Code.ToString());
//LoadtheDetailelementoftheSoaopExceptionobject
XmlDocumentdoc=newXmlDocument();
doc.LoadXml(soapEx.Detail.OuterXml);
XmlNamespaceManagernsManager=new
XmlNamespaceManager(doc.NameTable);
//AddthenamespacetotheNamespaceManager
nsManager.AddNamespace("errorNS",
"http://tempuri.org/CategoriesService");
XmlNodecategoryNode=
doc.DocumentElement.SelectSingleNode("errorNS:Error",
nsManager);
stringerrorNumber=
categoryNode.SelectSingleNode("errorNS:ErrorNumber",
nsManager).InnerText;
stringerrorMessage=
categoryNode.SelectSingleNode("errorNS:ErrorMessage",
nsManager).InnerText;
stringerrorSource=
categoryNode.SelectSingleNode("errorNS:ErrorSource",
nsManager).InnerText;
MessageBox.Show("ErrorNumberis" errorNumber);
MessageBox.Show("ErrorMessageis" errorMessage);
MessageBox.Show("ErrorSourceis" errorSource);
}
catch(Exceptionex)
{
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数据中删除元素,运行客户程序 。将会得到一个消息,表明异常的原因是客户程序,除此之外,还可以在SoapException对象中得到更多的异常信息 。
正如前面所提到的那样,如果Web服务失败是由于服务器端的一些问题引起的,那么SoapException对象的Code属性应该被设置为Server 。为了测试这个,修改Web服务中的连接字符串为一个无效值 。现在,如果运行客户程序,将会得到一个表明异常的原因是Server的消息(该例中的Web服务) 。

推荐阅读