ASP.NET Core MVC 项目 AOP之IAlwaysRunResultFilter

目录

一:说明

二:IAlwaysRunResultFilter同步

三:IAsyncAlwaysRunResultFilter异步


一:说明

设置Context.Result结果后,程序不再继续执行,可以利用IAlwaysRunResultFilter或IAsyncAlwaysRunResultFilter特性让程序继续执行。

使用IAlwaysRunResultFilter特性搭配IResourceFilter或IResultFilter或IActionFilter效果会更好。

本案例搭配IResourceFilter特性。


未使用IAlwaysRunResultFilter同步过滤器执行顺序:

1:执行ResourceFilter.OnResourceExecuting方法

2:执行控制器中的构造函数,实例化控制器

3:执行具体的Action方法

4:执行ResourceFilter.OnResourceExecuted方法

5:缓存之后,只执行ResourceFilter.OnResourceExecuting方法,不再继续执行。


使用IAlwaysRunResultFilter同步过滤器执行顺序:

1:执行ResourceFilter.OnResourceExecuting方法

2:执行控制器中的构造函数,实例化控制器

3:执行具体的Action方法

4:执行AlwaysRunResultFilter.OnResultExecuting方法

5:执行AlwaysRunResultFilter.OnResultExecuted方法

6:执行ResourceFilter.OnResourceExecuted方法

7:缓存之后,继续执行AlwaysRunResultFilter.OnResultExecuting方法

8:继续执行AlwaysRunResultFilter.OnResultExecuted方法


未使用IAsyncAlwaysRunResultFilter异步过滤器执行顺序:

1:执行ResourceFilter.OnResourceExecuting方法

2:执行控制器中的构造函数,实例化控制器

3:执行具体的Action方法

4:执行ResourceFilter.OnResourceExecuted方法

5:缓存之后,只执行ResourceFilter.OnResourceExecuting方法,不再继续执行。


使用IAsyncAlwaysRunResultFilter异步过滤器执行顺序:

1:执行ResourceFilter.OnResourceExecuting方法

2:执行控制器中的构造函数,实例化控制器

3:执行具体的Action方法

4:执行AlwaysRunResultFilter.OnResultExecutionAsync方法

5:执行ResourceFilter.OnResourceExecuted方法

6:缓存之后,继续执行IAsyncAlwaysRunResultFilter.OnResultExecutionAsync方法

7:继续执行ResourceFilter.OnResourceExecuted方法


二:IAlwaysRunResultFilter同步

控制器代码:

 
        /// <summary>
        /// Get请求
        /// 应用ResourceFilter扩展
        /// 应用AlwaysRunResultFilter扩展
        /// Home控制器的Index
        /// </summary>
        /// <returns>Index视图</returns>
        [HttpGet]
        [ResourceFilter]
        [AlwaysRunResultFilter]
        public IActionResult Index()
        {
            ViewBag.DateTime = DateTime.Now.ToString("HH:mm:ss");
            return View();
        }

视图代码:

@{
    ViewData["Title"] = "Home Page";
}

<h2>来自于控制器的计算结果:@ViewBag.DateTime</h2>
<h2>来自于视图中的计算结果:@DateTime.Now.ToString("HH:mm:ss")</h2>

关键类ResourceFilter代码:

using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.Filters;

namespace Study_ASP.NET_Core_MVC.Utility.Filters
{
    public class ResourceFilter : Attribute, IResourceFilter
    {
        /// <summary>
        /// 初始化缓存构造函数
        /// </summary>
        private static Dictionary<string, object> CacheDictionary = new Dictionary<string, object>();
        /// <summary>
        /// 在XXX资源之前
        /// </summary>
        /// <param name="context"></param>
        public void OnResourceExecuting(ResourceExecutingContext context)
        {
            string pathKey = context.HttpContext.Request.Path;
            if (CacheDictionary.ContainsKey(pathKey))
            {
                context.Result = (IActionResult)CacheDictionary[pathKey];
            }
            Console.WriteLine("CustomResourceFilterAttribute.OnResourceExecuting方法");
        }
        /// <summary>
        /// 在XXX资源之后
        /// </summary>
        /// <param name="context"></param>
        public void OnResourceExecuted(ResourceExecutedContext context)
        {
            string pathKey = context.HttpContext.Request.Path;
            CacheDictionary[pathKey] = context.Result;
            Console.WriteLine("CustomResourceFilterAttribute.OnResourceExecuted方法");
        }
    }
}

关键类AlwaysRunResultFilter代码:

using Microsoft.AspNetCore.Mvc.Filters;

namespace Study_ASP.NET_Core_MVC.Utility.Filters
{
    public class AlwaysRunResultFilter : Attribute, IAlwaysRunResultFilter
    {
        /// <summary>
        /// 在XXX执行之前
        /// </summary>
        /// <param name="context"></param>
        /// <exception cref="NotImplementedException"></exception>
        public void OnResultExecuting(ResultExecutingContext context)
        {
            Console.WriteLine("在XXX执行之前AlwaysRunResultFilter.OnResultExecuting方法");
        }
        /// <summary>
        /// 在XXX执行之后
        /// </summary>
        /// <param name="context"></param>
        /// <exception cref="NotImplementedException"></exception>
        public void OnResultExecuted(ResultExecutedContext context)
        {
            Console.WriteLine("在XXX执行之前AlwaysRunResultFilter.OnResultExecuted方法");
        }
    }
}

结果截图:

三:IAsyncAlwaysRunResultFilter异步

控制器代码:

 
        /// <summary>
        /// Get请求
        /// 应用ResourceFilter扩展
        /// 应用AlwaysRunResultAsyncFilter扩展
        /// Home控制器的Index
        /// </summary>
        /// <returns>Index视图</returns>
        [HttpGet]
        [ResourceFilter]
        [AlwaysRunResultAsyncFilter]
        public IActionResult Index()
        {
            ViewBag.DateTime = DateTime.Now.ToString("HH:mm:ss");
            return View();
        }

视图代码:

@{
    ViewData["Title"] = "Home Page";
}

<h2>来自于控制器的计算结果:@ViewBag.DateTime</h2>
<h2>来自于视图中的计算结果:@DateTime.Now.ToString("HH:mm:ss")</h2>

关键类ResourceFilter代码:

using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.Filters;

namespace Study_ASP.NET_Core_MVC.Utility.Filters
{
    public class ResourceFilter : Attribute, IResourceFilter
    {
        /// <summary>
        /// 初始化缓存构造函数
        /// </summary>
        private static Dictionary<string, object> CacheDictionary = new Dictionary<string, object>();
        /// <summary>
        /// 在XXX资源之前
        /// </summary>
        /// <param name="context"></param>
        public void OnResourceExecuting(ResourceExecutingContext context)
        {
            string pathKey = context.HttpContext.Request.Path;
            if (CacheDictionary.ContainsKey(pathKey))
            {
                context.Result = (IActionResult)CacheDictionary[pathKey];
            }
            Console.WriteLine("CustomResourceFilterAttribute.OnResourceExecuting方法");
        }
        /// <summary>
        /// 在XXX资源之后
        /// </summary>
        /// <param name="context"></param>
        public void OnResourceExecuted(ResourceExecutedContext context)
        {
            string pathKey = context.HttpContext.Request.Path;
            CacheDictionary[pathKey] = context.Result;
            Console.WriteLine("CustomResourceFilterAttribute.OnResourceExecuted方法");
        }
    }
}

关键类AlwaysRunResultAsyncFilter代码:

using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.Filters;

namespace Study_ASP.NET_Core_MVC.Utility.Filters
{
    public class AlwaysRunResultAsyncFilter : Attribute, IAsyncAlwaysRunResultFilter
    {
        /// <summary>
        /// 在XXX执行时
        /// </summary>
        /// <param name="context"></param>
        /// <param name="next"></param>
        /// <returns></returns>
        /// <exception cref="NotImplementedException"></exception>
        public async Task OnResultExecutionAsync(ResultExecutingContext context, ResultExecutionDelegate next)
        {
            Console.WriteLine("在XXX执行之前AlwaysRunResultAsyncFilter.OnResultExecutionAsync方法");
            await next.Invoke();
            Console.WriteLine("在XXX执行之后AlwaysRunResultAsyncFilter.OnResultExecutionAsync方法");
        }
    }
}

结果截图:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
SQLSugar是一种ORM(对象关系映射)工具,可以帮助我们更轻松地操作数据库。下面是在ASP.NET Core MVC中使用SQLSugar进行多表查询的步骤: 1. 安装SQLSugar包 使用NuGet包管理器或通过命令行安装SQLSugar包。 2. 配置连接字符串 在appsettings.json文件中配置数据库连接字符串,例如: ``` "ConnectionStrings": { "DefaultConnection": "Server=localhost;Database=databaseName;User Id=userId;Password=password;" } ``` 3. 配置SQLSugar实例 在Startup.cs文件中的ConfigureServices方法中添加以下代码来配置SQLSugar实例: ``` services.AddScoped<ISqlSugarClient>(provider => { var connectionString = Configuration.GetConnectionString("DefaultConnection"); var db = new SqlSugarClient(new ConnectionConfig { ConnectionString = connectionString, DbType = DbType.MySql, IsAutoCloseConnection = true, InitKeyType = InitKeyType.Attribute }); db.Aop.OnLogExecuting = (sql, pars) => { Console.WriteLine($"{sql} {string.Join(",", pars.Select(p => $"{p.ParameterName}={p.Value}"))}"); }; return db; }); ``` 这里使用了MySQL数据库,如果你使用的是其他类型的数据库,请根据需要进行修改。 4. 创建实体类 在Models文件夹下创建对应的实体类,例如: ``` public class Order { public int Id { get; set; } public int CustomerId { get; set; } public decimal TotalAmount { get; set; } public DateTime OrderDate { get; set; } } ``` ``` public class Customer { public int Id { get; set; } public string Name { get; set; } public string Email { get; set; } } ``` 5. 进行多表查询 在Controller中使用SQLSugar实例进行多表查询,例如: ``` public class OrderController : Controller { private readonly ISqlSugarClient _db; public OrderController(ISqlSugarClient db) { _db = db; } public IActionResult Index() { var orders = _db.Queryable<Order, Customer>((o, c) => o.CustomerId == c.Id) .Select((o, c) => new { o.Id, c.Name, o.TotalAmount, o.OrderDate }) .ToList(); return View(orders); } } ``` 这里的多表查询是在Order表和Customer表之间进行的,通过CustomerId和Id进行关联。查询返回的结果是一个匿名类型,包含了订单的Id、客户的姓名、订单的总金额、订单的日期等信息。最后,将查询结果传递给View进行显示。 以上就是使用SQLSugar在ASP.NET Core MVC中进行多表查询的基本步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Vin Cente

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值