实现filter接口的类需要重写啥方法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了实现filter接口的类需要重写啥方法相关的知识,希望对你有一定的参考价值。

参考技术A 要实现一个Filter,我们需要继承自FilterAttribute类同时实现上面的一个或几个接口:
public
class
MyFilter
:
FilterAttribute,
IActionFilter,
IResultFilter


  这几个接口提供的方法如下:
  上图的方法和Filter接口对应的方法按名称对号入座就可以。
  IActionFilter接口有两个方法:
  其中OnActionExecuting在执行Action方法之前会被调用,OnActionExecuted会在Action方法执行后调用。注意他们的参数分别是ActionExecutingContext和ActionExecutedContext。
  ActionExecutedContext类包含一个
Canceled的属性,允许你取消当前的Action(怎么原来在P3中是在ActionExecutingContext的Canceled属性在P5中没有了呢?神奇.那么在OnActionExecuting的时候怎么取消一个Action呢?)。
  FilterExcutedContext
类包含一个Exception属性和一个ExceptionHandled属性。如果Exception属性为null,则没有异常在action
stack中,表明Action方法运行并没有发生错误。反之则为出现异常。如果将ExceptionHandled属性设置为true则表明在这个
Filter中已经处理了异常。
  IResultFilter接口也提供了两个方法:
  他们分别在Action返回结果(例如return
View();)之前和之后执行。和IActionFilter差不多就不多说了。
  IAuthorizationFilter是一个用于身份验证的Filter。只提供了一个void
OnAuthorization(AuthorizationContext
filterContext)方法。
  IExceptionFilter会在出现异常的时候调用,也是只
提供一个void
OnException(ExceptionContext
filterContext)的方法;
  这些Filter可以被应用在类或者方法上,下面我们来看一下他们的执行顺序。首先我们写一个BaseController并加上两个Filter:
[MyFilter2(Target
=
"BaseController")]
[MyFilter1(Target="BaseController")]
public
class
BaseController
:
Controller


  应为Controller类是实现这几个Filter接口的,所以我们在HomeController中重写Controller基类中的所有Filter接口的方法,并在HomeController类和里面的Filter方法加上我们自定义的MyFilter:
[MyFilter2(Target
=
"HomeController")]
//[MyFilter1(Target
=
"HomeController")]//注意我在这里把MyFilter1注释了.
[HandleError]
public
class
HomeController
:
BaseController

 [MyFilter2(Target
=
"HomeController.Filter")]
 [MyFilter1(Target
=
"HomeController.Filter")]
 public
ActionResult
Filter()
 
  return
Content("
这是在Action方法里面返回的内容!
");
 
 protected
override
void
OnActionExecuted(ActionExecutedContext
filterContext)
 
  filterContext.HttpContext.Response.Write("
这是在HomeController里面重写OnActionExecuted方法添加的内容!
");
 
 protected
override
void
OnActionExecuting(ActionExecutingContext
filterContext)
 
  filterContext.HttpContext.Response.Write("
这是在HomeController里面重写OnActionExecuting方法添加的内容!
");
 
 protected
override
void
OnAuthorization(AuthorizationContext
filterContext)
 
  filterContext.HttpContext.Response.Write("
这是在HomeController里面重写OnAuthorization方法添加的内容!
");
 
 protected
override
void
OnException(ExceptionContext
filterContext)
 
  filterContext.HttpContext.Response.Write("
这是在HomeController里面重写OnException方法添加的内容!
");
  filterContext.ExceptionHandled
=
true;
 
 protected
override
void
OnResultExecuted(ResultExecutedContext
filterContext)
 
  filterContext.HttpContext.Response.Write("
这是在HomeController里面重写OnResultExecuted方法添加的内容!
");
 
 protected
override
void
OnResultExecuting(ResultExecutingContext
filterContext)
 
  filterContext.HttpContext.Response.Write("
这是在HomeController里面重写OnResultExecuting方法添加的内容!
");
 

java中,一个类实现某个接口,必须重写接口中的所有方法吗?

 

不一定,关键要看子类是否是抽象类。

如果子类是非抽象类,则必须实现接口中的所有方法;
如果子类是抽象类,则可以不实现接口中的所有方法,因为抽象类中允许有抽象方法的存在!
1、抽象类定义
抽象类往往用来表征对问题领域进行分析、设计中得出的抽象概念,是对一系列看上去不同,但是本质上相同的具体概念的抽象。通常在编程语句中用 abstract 修饰的类是抽象类。在C++中,含有纯虚拟函数的类称为抽象类,它不能生成对象;在java中,含有抽象方法的类称为抽象类,同样不能生成对象。抽象类是 不完整的,它只能用作基类。在面向对象方法中,抽象类主要用来进行类型隐藏和充当全局变量的角色。
2、抽象类特点
1)抽象类不能实例化。
2)抽象类可以包含抽象方法和抽象访问器。
3)不能用 sealed 修饰符修饰抽象类,因为这两个修饰符的含义是相反的。 采用 sealed 修饰符的类无法继承,而 abstract 修饰符要求对类进行继承。
4)从抽象类派生的非抽象类必须包括继承的所有抽象方法和抽象访问器的实际实现。
3、与具体类的比较

1)抽象类不能直接实例化,并且对抽象类使用 new 运算符会导致编译时错误。虽然一些变量和值在编译时的类型可以是抽象的,但是这样的变量和值必须或者为 null,或者含有对非抽象类的实例的引用(此非抽象类是从抽象类派生的)。
2)允许(但不要求)抽象类包含抽象成员。
3)抽象类不能被密封。
4、与接口的比较
1)相同点

a、不能实例化;
b、包含未实现的方法声明;
c、派生类必须实现未实现的方法,抽象类是抽象方法,接口则是所有成员(不仅是方法包括其他成员)
2)不同点

a、类可以实现无限个接口,但仅能从一个抽象(或任何其他类型)类继承,从抽象类派生的类仍可实现接口,从而得出接口是用来解决多重继承问题的。
b、抽象类当中可以存在非抽象的方法,可接口不能,且它里面的方法只是一个声明必须用public来修饰没有具体实现的方法。
c、抽象类中的成员变量可以被不同的修饰符来修饰,可接口中的成员变量默认的都是静态常量(static final)。
d、抽象类是对象的抽象,然而接口是一种行为规范。

以上是关于实现filter接口的类需要重写啥方法的主要内容,如果未能解决你的问题,请参考以下文章

struts2中的类型转换,自定义类型转换器需要继承啥类

jsp题库啥是serverlet过滤器?作用是?

java中,实现接口的方法的过程是重写吗?

java中,实现接口的方法的过程是重写吗?

java中接口和类有啥区别 java中接口和类有啥区别

java中创建线程的两种方式有啥区别