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

本文介绍了企业应用程序体系结构层异常处理应用程序块,它支持全体系结构层异常处理,可在管理层定义维护策略,提供常用功能,能合并处理程序。还阐述了策略、异常类型、处理器等概念,并给出编写示例程序的步骤。
  Enterprise Library Step By Step 系列(十一):异常处理应用程序块——入门篇

作者:Terrylee

一.概述

使开发人员和决策人员能够针对发生在企业应用程序体系结构层的异常处理创建一致的策略。它的实现方法如下:

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.gifContractedBlock.gif dot.gif {
 6ExpandedSubBlockStart.gifContractedSubBlock.gif    /**//// <summary>
 7InBlock.gif    /// 功能说明:创建一个包装异常的类,需要继承ApplicationException
 8InBlock.gif    /// 程序作者:Terrylee
 9InBlock.gif    /// 编写日期:2005年11月13日
10ExpandedSubBlockEnd.gif    /// </summary>

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

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

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

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

29InBlock.gif
30ExpandedSubBlockStart.gifContractedSubBlock.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.gifContractedSubBlock.gif        dot.gif{
37InBlock.gif
38ExpandedSubBlockEnd.gif        }

39InBlock.gif
40ExpandedSubBlockStart.gifContractedSubBlock.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.gifContractedSubBlock.gif        dot.gif{
47InBlock.gif
48ExpandedSubBlockEnd.gif        }

49ExpandedSubBlockEnd.gif    }

50ExpandedBlockEnd.gif}

51 None.gif

2.打开配置工具,创建一个异常应用程序块。

 EE01.JPG

3.创建一个策略。

 EE02.JPG

4.命名为Wrap Policy

 EE03.JPG

5.创建一个异常类型Exception

 EE04.JPG

6.创建一个异常处理器,命名为Wrap Handler,选择它的WrapExceptionTypeName为我们刚才创建的那个异常包装类。

 EE05.JPG

7.同样,再创建一个替换策略和日志策略,分别命名为Replace PolicyLog Policy,注意Log Policy依赖于日志和监测应用程序块。

8.拷贝目录(我每次都说,大家可能会觉着烦^_^,不过我自己总是忘了这一条,所以不得不每次提醒大家)。

None.gif copy  " $(ProjectDir)\*.config "   " $(TargetDir) "   >  Nul

9.在程序中编写代码(代码编写很简单)。

 1 ExpandedBlockStart.gif ContractedBlock.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.gifContractedBlock.gif         dot.gif {
 8InBlock.gif            try
 9ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
10InBlock.gif                Exception ex = new Exception();
11InBlock.gif                throw ex;
12ExpandedSubBlockEnd.gif            }

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

21ExpandedSubBlockEnd.gif            }

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

31ExpandedSubBlockEnd.gif            }

32ExpandedBlockEnd.gif        }

33 None.gif        
34 ExpandedBlockStart.gifContractedBlock.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.gifContractedBlock.gif         dot.gif {
41InBlock.gif            try
42ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
43InBlock.gif                Exception ex = new Exception();
44InBlock.gif                throw ex;
45ExpandedSubBlockEnd.gif            }

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

54ExpandedSubBlockEnd.gif            }

55ExpandedBlockEnd.gif        }

56 None.gif        
57 ExpandedBlockStart.gifContractedBlock.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.gifContractedBlock.gif         dot.gif {
64InBlock.gif            try
65ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
66InBlock.gif                Exception ex = new Exception();
67InBlock.gif                throw ex;
68ExpandedSubBlockEnd.gif            }

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

77ExpandedSubBlockEnd.gif            }

78ExpandedBlockEnd.gif        }

10.执行程序,单击日志策略。在事件查看器中查看相应的日志记录。

结束语:异常处理应用程序块相对于其他应用程序块来说是比较简单的,入门篇里就介绍这么多了J

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值