MVC 过滤器

首先给大家分享一句名言:

                 每个人在他生活中都经历过不幸和痛苦。

          有些人在苦难中只想到自己,他就悲观消极发出绝望的哀号;

有些人在苦难中还想到别人,想到集体,想到祖先和子孙,想到祖国和全人类,他就得到乐观和自信。

 给评论,我就告诉你谁说的#24  哈哈#18

 

 

 

   我经历了过滤器的苦难,我想到了还有不会的芸芸众生!

           所以,我来了,我将给你们来过滤器的辉煌!!!

废话不多说!Come On!Baby!

今天咱们来研究一下----过滤器

在研究之前,难免会有几个问题,譬如:

1:什么是咱们程序中的过滤器?

2:这个过滤器又有什么作用那?

3:它的具体又是怎么实现的那?

下面,咱们就带着这三个问题来学习一下,咱们所说的过滤器,到底是怎么一回事!!!

                 第一讲:别认为它很难掌握,理论功底要扎根!

过滤器:字面直译不难理解,无非就是把不需要的东西过滤掉,剩下有用的东西,就像咱们平时生活中用的漏勺一样。我想这个比喻应该很恰当了吧!

       这只是咱们生活中对过滤器的理解!

但是,在咱们的MVC中,或者说咱们的程序当中,这个过滤器又是一个什么样的东东呢?

Filter(过滤器)是基于AOP(面向接口编程)的设计,它的作用是对MVC框架处理客户端请求注入额外的逻辑,以非常简单优美的方式实现横切关注点(Cross-cutting Concerns)

横切关注点是指:横越应该程序的多个甚至所有模块的功能,经典的横切关注点有日志记录、缓存处理、异常处理和权限验证等。

过滤器的本质:就是一个实现了特定接口或者父类的特殊类。

 那么问题来了?

它实现了,或者说继承了什么特定的接口或者父类那?

答案是:咱们自定义的过滤器必须满足的两个条件

1:必须继承FilterAttribute这个抽象类    这个类的命名空间是System.Web.Mvc;

2:必须实现了实现四个接口中的任何一个。

那么,这四个接口分别又是什么那?不要急,咱接着往下看:

MVC过滤器一共分为四个:ActionFilter(控制器过滤器),ResultFilter(结果过滤器),AuthorizationFilter(授权过滤器),ExceptionFilter(异常处理过滤器)。

这四个过滤器又继承那些接口?又有什么作用那?看完下面的图片,我想大家应该就会明白一些了!

技术分享

需要注意:

IAuthorizationFilter:在所有的Filter中最早执行的,可用于Action的权限控制

IActionFilter:在Action执行的前后,可用于请求跳转、记录Action执行日志

   OnActionExecuted:在Action执行之后执行!

   OnActionExecuting:在Action执行之前执行!  下面的Demo中就是讲解的这两个方法

具体看下图有介绍:

技术分享

IResultFilter:在Result执行的前后,可用于记录Result执行日志

IExceptionFilter:在任何异常发生时,可用于记录日志、处理异常、指定错误页面

                 第二讲:熟能生巧,无功自破!

学了上面的一些基本内容,为了加深下印象和更深入的理解,咱们来写一个Demo!

第一步:首先创建一个咱们需要的MVC项目,效果图和步骤说明如下图所示:

技术分享

 

点击确定后,会弹出一个选项框,按照,下图指示完成即可:

技术分享

 

这样咱们的一个MVC项目就创建完成了 !

技术分享

 

第二步:创建控制器和相应的试图,右键点击Controllers→添加→控制器

如下图:

技术分享

弹出框后,更改控制器名字,点击确定,即可完成创建控制器!

效果图:

技术分享

控制器创建完成后的效果图如下:

技术分享

右键点击Index(),然后选择添加试图,弹出框如下

技术分享

 

记住:试图名要和Action的名称一致,点击添加后的界面如下:

技术分享

第三步:查看没用过滤器之前的效果

以上步骤都完成以后,咱们可以先来看一下现在的效果了:

技术分享

运行效果如下:

技术分享

 

下面咱们就来看下:加上过滤器后的效果又会是什么样子的呢?

第四步:添加咱们用户自己定义的过滤器!

右键点击项目名称→添加→新建文件夹

技术分享

 

 

 

技术分享

把文件夹的名字改成Filter就OK了!接下来的步骤就很重要了,创建咱们第一个自定义的过滤器

右键点击Filter→添加→类

技术分享

弹出的窗体如下:写上类的名称,点击添加即可:

 

技术分享

 

类创建完成后的效果图如下:

技术分享

 

第五步:完善咱们创建的过滤器

咱们继续往下进行了,写什么?看注释,俺写的非常的详细!

 

技术分享

继续写代码

技术分享

 

这样下来,咱们的这个过滤器算是写完了,关键的一步又来了!

我在控制器中怎么实现呢?别急,容在下慢慢道来!

首先返回咱们的HomeController页面;

写什么?就写咱们刚才定义好的这个DemoFilter过滤器名称就行了

效果图如下:

技术分享

第六步:运行,看效果:

技术分享

蓝色框:代表OnActionExected()方法里面的输出;

红色框:代表Action里面的输出;

绿色框:代表OnActionExecting()方法里面的输出。

 

有的人就会说了,你写了这么多,就说了两个简单的方法,实际开发中没有多大的意义啊!!

那么咱们就来点有意义的,用咱写的过滤器记录一下错误日志,并保存在项目的根目录下!

                       第三讲:没有意义的意义

由于上面的步骤我说的已经很详细了,要是还看不懂,留言喷我!!!

那咱们就接着上面的步骤,稍微添加一下代码就行了!

就不过多解释了。谢谢!!!

第一步:在原有的Filter文件夹下新建一个ExceptionFilter类

技术分享

 

第二步:书写咱们的ExceptionFilter过滤器

技术分享

继续编写代码:

 技术分享

上文中的地址~/代表:项目的根目录,也就是这个错误日志存放的位置!

第三步:在HomeConttroller页面调用咱们写好的ExceptionFilter过滤器

技术分享

 

第四步:运行看结果:

1:首先是程序中报错:

技术分享

 

2:浏览器报错:

技术分享

 

咱们的目的是记录错误日志,所以咱们就得去项目的根目录去寻找!

第五步:找到错误日志,打开看内容

右键点击项目名称→在文件资源管理器中打开文件夹

技术分享

 

打开后效果图如下:

技术分享

双击打开errorlog.txt文件后的效果如下:

技术分享

 

     就写了这一个贯穿的案列,希望对您有帮助!谢谢!

               日积月累,滴水穿石!

 

我遇到的问题:

报错了!效果图如下:

技术分享

技术分享

原因分析

throw new NotImplementedException() 这句话没有删除!

这句话是Visual Studio默认生成的,是为了提醒程序员要实现这个接口中的方法。

解决方法:

删除 throw new NotImplementedException()这句话即可!

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。