Enterprise Library Step By Step系列(十一):异常处理应用程序块——入门篇

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:
一.概述
使开发人员和决策人员能够针对发生在企业应用程序体系结构层的异常处理创建一致的策略。它的实现方法如下:
1)它支持整个应用程序体系结构层的异常处理,而不仅限于服务接口的界限。
2)它使得异常处理策略可以在管理层定义和维护,以便决策人员(可能是系统管理员和开发人员)可以定义如何处理异常。他们可以维护和修改控制异常处理的规则集,而无需更改块的应用程序代码。
3)它提供了常用的异常处理功能,例如记录异常信息的功能、通过将原始异常替换为其他异常来隐藏敏感信息的功能,以及通过将原始异常打包到另一个异常中来添加异常的上下文信息的功能。这些功能封装在名为 Exception handlers  .NET 类中。
4)它可以合并多个异常处理程序以产生某个异常所需的响应,例如先记录异常信息,再将原始异常替换为其他异常。
5)它使开发人员能够创建自己的异常处理程序。
6)它以一致的方式调用异常处理程序。这意味着,处理程序可以在应用程序之中和之间的多种场合下使用。
常见情况
异常处理应用程序块被设计为支持包含在应用程序组件的 catch 语句中的典型代码。该应用程序块允许开发人员将此逻辑封装为可重用的异常处理程序,而不是在应用程序组件的相同 catch 块中重复这段代码(例如,记录异常信息)。异常处理程序是封装异常处理逻辑和实现名为 IExceptionHandler 的异常处理应用程序块接口的 .NET 类。异常处理应用程序块包含三个异常处理程序:
包装处理程序: 此异常处理程序可将一个异常包装到另一个异常中。
替换处理程序: 此异常处理程序可将一个异常替换为另一个异常。
日志处理程序: 此异常处理程序可格式化异常信息,例如消息和堆栈跟踪等。然后,日志处理程序将该信息提供给企业程序库日志和规范应用程序块,以便可以将它发布。
异常处理应用程序块可让您将异常类型与指定的策略相关联。您可以使用配置控制台来完成此项工作。策略可指定在应用程序块处理特定异常类型时执行的异常处理程序。您可以将这些处理程序串联起来,这样,在处理关联的异常类型时就可以执行一系列处理程序
二.几个重要的概念
1 .策略:
确定一系列的异常类型是如何拦截并处理的
每一个策略可以包含多个异常类型
每个应用程序支持多个异常策略
2 .异常类型:
可以使用 Exception 功能的异常类型应该是一个 System.Exception 类型或从此类继承下来的类
每一个异常类型可以包含一个或多个 Handler
每一个异常均可以通过映射到 .NET 中的特定类型,从而被处理
3 .处理器:
异常捕获后进行处理的方式有日志,包装,替换等;
每一个异常类型可以有多个异常处理器;
每一个异常捕获处理器均有机会修改原有异常;
每一个异常捕获处理器均有机会将自己的信息通过异常传递给下一个异常处理程序;
三.编写示例程序:
1 .在开始进行配置之前,我们先编写一个异常包装的类。
 1 None.gif using  System;
 2 None.gif using  System.Runtime.Serialization;
 3 None.gif
 4 None.gif namespace  EnterpriseExceptionHandler
 5 ExpandedBlockStart.gif {
 6ExpandedSubBlockStart.gif    /// <summary>
 7InBlock.gif    /// 功能说明:创建一个包装异常的类,需要继承ApplicationException
 8InBlock.gif    /// 程序作者:Terrylee
 9InBlock.gif    /// 编写日期:2005年11月13日
10ExpandedSubBlockEnd.gif    /// </summary>

11InBlock.gif    public class ExceptionHelper:ApplicationException
12ExpandedSubBlockStart.gif    {
13ExpandedSubBlockStart.gif        /// <summary>
14InBlock.gif        /// 默认的构造函数
15ExpandedSubBlockEnd.gif        /// </summary>

16InBlock.gif        public ExceptionHelper() : base() 
17ExpandedSubBlockStart.gif        {
18InBlock.gif
19ExpandedSubBlockEnd.gif        }

20InBlock.gif
21ExpandedSubBlockStart.gif        /// <summary>
22InBlock.gif        /// 序列化错误信息
23InBlock.gif        /// </summary>
24ExpandedSubBlockEnd.gif        /// <param name="message">错误信息</param>

25InBlock.gif        public ExceptionHelper(string message) : base(message) 
26ExpandedSubBlockStart.gif        {
27InBlock.gif
28ExpandedSubBlockEnd.gif        }

29InBlock.gif
30ExpandedSubBlockStart.gif        /// <summary>
31InBlock.gif        /// 序列化错误信息,内部异常产生的原因.
32InBlock.gif        /// </summary>
33InBlock.gif        /// <param name="message">错误信息</param>
34ExpandedSubBlockEnd.gif        /// <param name="exception">引起当前的异常</param>

35InBlock.gif        public ExceptionHelper(string message, Exception exception) : base(message, exception) 
36ExpandedSubBlockStart.gif        {
37InBlock.gif
38ExpandedSubBlockEnd.gif        }

39InBlock.gif
40ExpandedSubBlockStart.gif        /// <summary>
41InBlock.gif        /// 序列化数据
42InBlock.gif        /// </summary>
43InBlock.gif        /// <param name="info">序列化的数据对象</param>
44ExpandedSubBlockEnd.gif        /// <param name="context">描述.</param>

45InBlock.gif        protected ExceptionHelper(SerializationInfo info, StreamingContext context) :base(info, context) 
46ExpandedSubBlockStart.gif        {
47InBlock.gif
48ExpandedSubBlockEnd.gif        }

49ExpandedSubBlockEnd.gif    }

50ExpandedBlockEnd.gif}

51 None.gif
2 .打开配置工具,创建一个异常应用程序块。
 
3 .创建一个策略。
 
4 .命名为 Wrap Policy
 
5 .创建一个异常类型 Exception
 
6 .创建一个异常处理器,命名为 Wrap Handler ,选择它的 WrapExceptionTypeName 为我们刚才创建的那个异常包装类。
 
7 .同样,再创建一个替换策略和日志策略,分别命名为 Replace Policy Log Policy ,注意 Log Policy 依赖于日志和监测应用程序块。
8 .拷贝目录(我每次都说,大家可能会觉着烦 ^_^ ,不过我自己总是忘了这一条,所以不得不每次提醒大家)。
None.gif copy  " $(ProjectDir)\*.config "   " $(TargetDir) "   >  Nul
9 .在程序中编写代码(代码编写很简单)。
 1 ExpandedBlockStart.gif /// <summary>
 2InBlock.gif        /// 包装策略
 3InBlock.gif        /// </summary>
 4InBlock.gif        /// <param name="sender"></param>
 5ExpandedBlockEnd.gif        /// <param name="e"></param>

 6 None.gif          private   void  btn_Wrap_Click( object  sender, System.EventArgs e)
 7 ExpandedBlockStart.gif         {
 8InBlock.gif            try
 9ExpandedSubBlockStart.gif            {
10InBlock.gif                Exception ex = new Exception();
11InBlock.gif                throw ex;
12ExpandedSubBlockEnd.gif            }

13InBlock.gif            catch(DllNotFoundException ex)
14ExpandedSubBlockStart.gif            {
15InBlock.gif                bool Flag = ExceptionPolicy.HandleException(ex,"Wrap Policy");
16InBlock.gif
17InBlock.gif                if(Flag)
18ExpandedSubBlockStart.gif                {
19InBlock.gif                    throw;
20ExpandedSubBlockEnd.gif                }

21ExpandedSubBlockEnd.gif            }

22ExpandedSubBlockStart.gif            ///我们可以多次捕获异常
23InBlock.gif            catch(Exception ex)
24ExpandedSubBlockStart.gif            {
25InBlock.gif                bool Flag = ExceptionPolicy.HandleException(ex,"Wrap Policy");
26InBlock.gif
27InBlock.gif                if(Flag)
28ExpandedSubBlockStart.gif                {
29InBlock.gif                    throw;
30ExpandedSubBlockEnd.gif                }

31ExpandedSubBlockEnd.gif            }

32ExpandedBlockEnd.gif        }

33 None.gif        
34 ExpandedBlockStart.gif         /// <summary>
35InBlock.gif        /// 替换策略
36InBlock.gif        /// </summary>
37InBlock.gif        /// <param name="sender"></param>
38ExpandedBlockEnd.gif        /// <param name="e"></param>

39 None.gif          private   void  btn_Replace_Click( object  sender, System.EventArgs e)
40 ExpandedBlockStart.gif         {
41InBlock.gif            try
42ExpandedSubBlockStart.gif            {
43InBlock.gif                Exception ex = new Exception();
44InBlock.gif                throw ex;
45ExpandedSubBlockEnd.gif            }

46InBlock.gif            catch(Exception ex)
47ExpandedSubBlockStart.gif            {
48InBlock.gif                bool Flag = ExceptionPolicy.HandleException(ex,"Replace Policy");
49InBlock.gif
50InBlock.gif                if(Flag)
51ExpandedSubBlockStart.gif                {
52InBlock.gif                    throw;
53ExpandedSubBlockEnd.gif                }

54ExpandedSubBlockEnd.gif            }

55ExpandedBlockEnd.gif        }

56 None.gif        
57 ExpandedBlockStart.gif         /// <summary>
58InBlock.gif        /// 日志策略
59InBlock.gif        /// </summary>
60InBlock.gif        /// <param name="sender"></param>
61ExpandedBlockEnd.gif        /// <param name="e"></param>

62 None.gif          private   void  btn_Log_Click( object  sender, System.EventArgs e)
63 ExpandedBlockStart.gif         {
64InBlock.gif            try
65ExpandedSubBlockStart.gif            {
66InBlock.gif                Exception ex = new Exception();
67InBlock.gif                throw ex;
68ExpandedSubBlockEnd.gif            }

69InBlock.gif            catch(Exception ex)
70ExpandedSubBlockStart.gif            {
71InBlock.gif                bool Flag = ExceptionPolicy.HandleException(ex,"Log Policy");
72InBlock.gif
73InBlock.gif                if(Flag)
74ExpandedSubBlockStart.gif                {
75InBlock.gif                    throw;
76ExpandedSubBlockEnd.gif                }

77ExpandedSubBlockEnd.gif            }

78ExpandedBlockEnd.gif        }
10 .执行程序,单击日志策略。在事件查看器中查看相应的日志记录。
结束语:异常处理应用程序块相对于其他应用程序块来说是比较简单的,入门篇里就介绍这么多了 J














本文转自lihuijun51CTO博客,原文链接:  http://blog.51cto.com/terrylee/67613 ,如需转载请自行联系原作者

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章