本文demo已上传至github:xinyuehtx/WCFdemo

这个博客会介绍如何设置服务的异常回馈


多进程之间调试,或者是客户端/服务器联调,很麻烦的一点是出了异常如何定位?

是客户端问题,还是服务端问题,抑或是信道问题?

这时候通过异常回馈将服务端发生的异常信息反馈给客户端就显得很重要。

错误协定(FaultContract)

服务操作可以标记错误协定,表明这个方法可能会出现指定错误。

1548901877615

示例中我们为SayHello方法指定了异常协定,表明可能会抛出详情信息为ServiceFault的异常。

1548902007086

ServiceFault是一个通过数据协定的标记的可序列化的类型。这里我们通过它将方法中的异常,和方法名称做了封装。

1548902141815

在服务实现中,我们通过抛出FaultException,将ServiceFault包装,传递给客户端

1548902547229

在客户端我们通过trycatch将异常打印出来

1548902524944

可以看到异常成功输出

错误协定风险

聪明的同学都已经注意到,我们刚刚试验的操作协定是请求答复模式的(同步方法)。那么对于单向模式会如何呢?

我们尝试将IsOneWay设置为True

1548902782652

抛出异常咯,单向方法不可以使用错误协定

1548902762319

小结

我们研究了WCF服务的错误协定,其特点有

  • 可以将服务端的指定错误回馈客户端,通过简单包装可以传递所有托管异常的基本信息
  • 协定传递的对象需要可以被数据协定序列化
  • 不能处理单向操作

参考链接:


本文会经常更新,请阅读原文: https://xinyuehtx.github.io/post/wcf%E5%85%A5%E9%97%A8-9.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

知识共享许可协议 本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名黄腾霄(包含链接: https://xinyuehtx.github.io ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系