ASP.Net Core --过滤器
2021-01-07 07:29
标签:直接 exe 添加 子接口 mod 路由 except configure news Filter 过滤器用于MVC,可以在MVC请求管道里添加逻辑,之前或之后,可以避免代码重复,比如授权,日志,对HTTP有要求等等。 比如: 再比如,需要HTTPS请求: 代码也很简洁,直接中括号,写上类名就行 看一下MVC和过滤器的关系:
当请求来到路由器后,可以有一个过滤器,模型验证完后还可以有过滤器,也就是进入controller之前,之后还可以有一个过滤器,ViewResult执行后也可以有一个过滤器 Filter种类 1:授权: 授权过滤器 在过滤器管道中第一个执行,通常用于验证当前请求的合法性,不合法后面的管道会直接跳过。它们只有一个 2:资源 资源过滤器是第二个运行,在 Authorization Filter 之后,Model Binding 之前执行。在性能方面,资源过滤器在实现缓存或截断过滤器管道尤为重要。 3:Action 使用率最高的过滤器,在调用 Acioin 方法之前和之后执行代码。跟 Resource Filter 很类似,但 Model Binding 在之后执行。 • 异常 4:异常 用于为应用程序执行异常处理策略。 5:Result 当 Action 执行完成后,最后会执行过滤器。用于处理ActionResult结果输出策略。 实现Filter 要是有自己定义的Filter,要实现IFilterMetadata这个接口,其实这个接口里边啥也没有,因为它不知道我们需要实现什么功能的Filter,针对以上五种类型,IFilterMetadata一下有五个子接口,分别是: 1:IAuthorizationFilter,IAsyncAuthorizationFilter 注:一个同步版本的还有一个异步版本的 2:IResourceFilter 3:IActionFilter 4:IExceptionFilter 5:IResultFilter 代码示例 新建一个LogResourceFilter.cs文件,如下: 里边两个方法,每个方法里都有一个参数,代表上下文,看名字就知道,一个是进行时,一个是过去时或者叫完成时也行。就是一个是在动作发生之前运行,一个是在动作完成后运行 1:ResourceExecutingContext 这个里边包含了HttpContext还有路由的一些东西,以及当前Action的一些信息 2:ResourceExecutedContext 这个和上边的不一样,包含了一些其它方面的东西,比如返回的IActionResult,具体内容可以对其进行反编译查看源码 这个类实现IResourceFilter这个接口,我们可以对这个接口进行反编译,如下:
可以看到,它就实现了IFilterMetadata这个接口。为什么实现Attribute这个接口?因为要在动作前边使用过滤器 这是同步的,我们再新建一个异步版本的,取名为LogAsyncResourceFilter.cs,如下: 这里边只有一个方法,因为是异步的嘛,有一个委托next,next里就包含了整个剩余的MVC管道里边的东西,在日常开发中,还是使用同步的版本比较好。 应用Filter 一共应用到三个地方 1:Action 2:Controller 3:全局 在Index上边使用LogResourceFilter这个过滤器,代码示例如下: 然后启动项目,打开控制台,如下:
一个index动作发生之前,一个在index动作发生之后。 如果放在Controller之前,那么无论进到那个动作,都会调用这两个方法,这里就不测试了。 全局应用Filter 既然是全局,那么肯定实在startup里添加了,需要在ConfigureServices方法里使用services.AddMvc()来添加 一共有三种方式,如下: 这样,不论在那个控制器里,那个动作发生,都会调用过滤器里边那两个方法,一个动作发生之前,一个动作发生之后! 这几种Filter的级别和执行顺序如下:
ASP.Net Core --过滤器 标签:直接 exe 添加 子接口 mod 路由 except configure news 原文地址:https://www.cnblogs.com/dcy521/p/13573880.html[Authorize]
public IActionResult Create()
{
return View();
}
[RequireHttps]
public IActionResult Create()
{
return View();
}
Before
方法,不像其它大多数过滤器支持前置阶段方法和后置阶段方法。注意,您不要在授权过滤器中抛出异常,因为没有任何代码来处理异常(异常过滤器不处理它们)。public class LogResourceFilter: Attribute, IResourceFilter
{
public void OnResourceExecuting(ResourceExecutingContext context)
{
Console.WriteLine("Executing Resource Filter!");
}
public void OnResourceExecuted(ResourceExecutedContext context)
{
Console.Write("Executed Resource Filter...");
}
}
public class LogAsyncResourceFilter : Attribute, IAsyncResourceFilter
{
public async Task OnResourceExecutionAsync(ResourceExecutingContext context, ResourceExecutionDelegate next)
{
Console.WriteLine("Executing async Resource Filter!");
var executedContext = await next();
Console.WriteLine("Executed async Resource Filter...");
}
}
[LogResourceFilter]
public IActionResult Index()
{
var studentList = _repository.GetAll();
var newStudentList = studentList.Select(x => new StudentViewModel
{
Name = $"{x.FirstName}+{x.LastName}",
Age = DateTime.Now.Subtract(x.BirthDate).Days / 365,
Id = x.Id
});
var list = new HomeIndexViewModel
{
studentList = newStudentList
};
return View(list);
}
services.AddMvc(options=>
{
options.Filters.Add(new LogResourceFilter());
options.Filters.Add(typeof(LogResourceFilter));
options.Filters.Add
上一篇:d3.js的基础使用
下一篇:Nginx系列:https配置