ASP.NET MVC笔记 之 Action 过滤器

    Action 过滤器在代码中体现为添加到Action上方的属性,MVC框架包含了一些过滤器,如:
    OutputCache –指示Controller在指定时间内缓存返回的结果。
    HandleError –处理Contrller中Action抛出的异常
    Authorize – 约束特定用户或角色对Action的访问
    另外你还可以自己定义过滤器,比如:你想使用自定义的验证机制;你想修改Action返回的数据等等。
    使用Action 过滤器
     Action 过滤器不仅可以控制单个Action,也可以控制整个Contrller。同时,一个Action可以应用多个过滤器。比如:

public class DataController : Controller
{
   [OutputCache(Duration
=10)]
   
public string Index()
   {
       
return DateTime.Now.ToString("T");
   }
}

这个Action返回了当前时间,但是你若在10秒钟内刷新界面,你会一直得到同一个值,因为这里使用了OutputCache(Duration=10)
    过滤器的类型
    ASP.NET MVC 框架支持以下几种过滤器:
    1、Authorization 过滤器– 实现了 IAuthorizationFilter 接口。这一类的过滤器用来实现用户验证和对Action的访问授权。比如Authorize 就属于Authorization 过滤器。
    2、Action 过滤器– 实现了 IActionFilter 接口。它可以包含一些Action执行前或者执行后的逻辑,比如有一些过滤器专门用来修改Action返回的数据。
    3、Result 过滤器– 实现了 IResultFilter 接口。它可以包含一些view result生成前或者生成后的逻辑,比如有一些过滤器专门用来修改视图向浏览器展现前的结果。
    4、Exception 过滤器– 实现了IExceptionFilter 接口。它用以用来处理Action或者Result的错误,也可以记录错误。
    过滤器的默认执行顺序也和上面的列表相同,比如Authorization 过滤器会先于Action 过滤器执行,而Exception 过滤器总会在最后执行。当然你也可以根据需要通过Order属性设定过滤器执行的顺序。
    自定义过滤器
    自定义过滤器必须继承System.Web.Mvc.FilterAttribute ,并且实现上述几个接口中的一个或者多个。MVC框架为了方便开发人员,预定义了一个ActionFilterAttribute 类,它已实现了IActionFilter 和IResultFilter 接口。你可以重载ActionFilterAttribute 类中以下几个方法:
OnActionExecuting – 在Action执行之前调用。
OnActionExecuted – 在Action执行之后调用。
OnResultExecuting – 在Result产生之前调用。
OnResultExecuted – 在Result产生之前调用。
下面示例一个类:    

Code

将LogActionFilter冠在某一个Action或者Controller上,就会打印对应Action的执行情况。如:

 

     [LogActionFilter]
     
public class HomeController : Controller
     {}

OutputCache过滤器
      你可以使用OutputCache过滤器来缓存的你查询结果,这样可以提高用户体验,也可以减少查询次数。它有以下属性:
Duration:缓存的时间,以秒为单位,理论上缓存时间可以很长,但实际上当系统资源紧张时,缓存空间还是会被系统收回。
VaryByParam:以哪个字段为标识来缓存数据,比如当“ID”字段变化时,需要改变缓存(仍可保留原来的缓存),那么应该设VaryByParam为"ID"。这里你可以设置以下几个值:
* = 任何参数变化时,都改变缓存。
none = 不改变缓存。
以分号“;”为间隔的字段名列表 = 列表中的字段发生变化,则改变缓存。

Location:缓存数据放在何处。缓存位置很重要,如果存在服务器上,那么所有用户看到的缓存视图都会一样,如果存在客户端,那么用户只会看到自己的缓存。比如:如果是一些私人信息,那就不能存在服务器上。你可以设置以下值:
· Any :默认值,输出缓存可位于产生请求的浏览器客户端、参与请求的代理服务器(或任何其他服务器)或处理请求的服务器上。

· Client:输出缓存位于产生请求的浏览器客户端上。

· Downstream 输出缓存可存储在任何 HTTP 1.1 可缓存设备中,源服务器除外。这包括代理服务器和发出请求的客户端。

· Server:输出缓存位于处理请求的 Web 服务器上。

· None:对于请求的页,禁用输出缓存。

· ServerAndClient:输出缓存只能存储在源服务器或发出请求的客户端中。代理服务器不能缓存响应。

NoStore:该属性定义一个布尔值,用于决定是否阻止敏感信息的二级存储。
除了直接在Action或者类的定义前加上属性,也可以使用配置文件,这样就可以动态配置你的缓存模式了。
在<system.web>节中,添加如下配置:

<caching>
<outputCacheSettings>
    
<outputCacheProfiles>
        
<add name="Cache1Hour" duration="3600" varyByParam="none"/>
    
</outputCacheProfiles>
</outputCacheSettings>
</caching>

那么在Controller中可以这样使用:

[OutputCache(CacheProfile="Cache1Hour")]
public string Index()
{
   return DateTime.Now.ToString("T");
}

[扩展]在已经缓存的页面上添加动态内容
为了提高用户体验,我们会使用缓存技术,但是有时我们会需要在页面上改变内容,如:提供一些动态信息、广告的变化等。
此时我们可以调用 HttpResponse.WriteSubstitution() 方法。
例如:

 

<% Response.WriteSubstitution(News.RenderNews); %>

其中News.RenderNews是一个静态方法,它的定义如下,这个方法用来随机显示三条广告词。   

Code

你甚至可以为Response.WriteSubstitution()方法扩展一个Helper方法,如下所示:
    

Code

那么你就可以在页面上如此调用:

 <% Html.RenderBanner(); %>

这样就会每刷新一次页,改变一次图像。但是数据内容却还是缓存的,并不会因为你刷新了页面而再次查询数据库。

posted @ 2009-04-07 15:10  Johnhormy  阅读(3413)  评论(8编辑  收藏  举报