MVC过滤器简单刨析
前言
简单介绍一下过滤器。
正文
看下过滤器类型:
action: 在动作方法之前及之后执行
result: 在action结果被执行前或者之后执行,比如说返回一个视图,再执行视图前执行一个方法,再执行之后执行一个方法
authorizationfilter:首先运行,看的出来一般是用来执行权限的,如果权限不够,那么后面没有,类似看门狗。
exption:异常时候执行,一般处理错误跳转。
这是mvc的一套系统,即使你不去写任何相关的代码,他们也会按照这个流程,检测,所以不能说框架是性能好的东西,只能说是有利于开发的东西。
有一个默认执行的过滤器:
F12进入:
这个就是处理我们异常的信息的过滤器。
来看下action类型吧。
建立一个类,然后去继承ActionFilterAttribute,覆盖上面的这两个方法。
这两个方法的含义,字面理解为正要执行和执行后。
加了一些东西,用于输出他们调用时候的时间,必须精确到毫秒,应为代码数据一般都用ms计算。
看下结果:
这个时候加入result 过滤器:
然后再次看下结合:
清晰明了,视图过程和他们的执行顺序都反映出来了。
看下onAuthoriaztion:
这个是最先运行的,也称权限控制器,继承: AuthorizeAttribute.
因为用的比较多了,有些必须登陆才可以使用的,可以把他放在全局中,有些部分的就放在自己的一个BaseControl中吧,然后继承。
看下异常过滤器:
最后一个处理异常的,继承HandleErrorAttribute,然后复写这个方法。
拿到异常,然后自定义错误的跳转,当然自己可以根据不同的情况自己设定。
一般会放在全局过滤器中。
如果没有执行,加上这个配置吧。
意思是定制的错误,方法启动。