MonoRail学习笔记九:Rescue的使用

Rescue是MonoRail中处理异常的一种机制
在asp.net或者java开发中我们都要进行异常处理,即发生异常时跳转到某一个错误页面。以前很多时候我们都是自动定义一种方式来处理的,在MonoRail中提供了一种现成的机制来处理异常

使用方式很简单,只要加入一个Rescue属性就可以了。
我们先来看看一个最简单的方式:


Controller代码:
    [Rescue( " /error " )]
    
public   class  ErrorController : SmartDispatcherController
    
{
        
public ErrorController()
        
{
        }

        [Rescue(
"/argerror"typeof(ArgumentException))]
        
public void Index()
        
{
            
//throw new ArgumentException("dddd");
            throw new Exception("fff");
        }

    }


vm代码:
< html >
< body >
< center >
    
< h2 > 出错了 </ h2 >
    $context.LastException.Message
</ center >
</ body >
</ html >

那么当我们调用/error/index.rails页面时,由于Index方法抛出Exception,那么会自动显示出/error.vm文件,并且在此文件中可以取得异常的信息
当Index方法抛出ArgrmentException时,会自动显示出/argerror.vm文件
也就是说Rescue属性可以定义在类和方法上,在类上定义的话对类中所有方法有效,在方法中定义的话会覆盖到类中同类的异常处理机制

有了这种机制之后,我们就可以定义自己的一个异常类,然后再定义一个父的controller类,指定Rescue属性,其他所有的controller类都从此类继承。这样,在我们的代码中就不需要再考虑异常的处理了,会自动由父类接管。

其他相关点:
当某个方法不需要此异常机制时,可以如下定义:

        [SkipRescue]
        
public   void  SkipAction()
        
{
            
//throw new ArgumentException("dddd");
            throw new Exception("fff");
        }

指定SkipRescue属性就可以了

你可能感兴趣的:(学习笔记)