ASP.NET Core 7引入统一输出缓存机制,通过AddOutputCache和UseOutputCache注册服务与中间件,支持全局、命名及匿名策略,可基于时间、查询参数、请求头等条件精细控制缓存行为,适用于Minimal API与控制器,提升性能并降低服务器负载。

ASP.NET Core 中的输出缓存通过 Output Caching 中间件实现,主要用于缓存整个 HTTP 响应内容,提升性能。从 ASP.NET Core 7 开始,官方引入了统一的输出缓存机制,取代了旧版中功能有限的 [OutputCache] 特性。
启用输出缓存服务
在 Program.cs 中注册输出缓存服务:
调用 AddOutputCache() 添加缓存服务 使用 UseOutputCache() 启用中间件var builder = WebApplication.CreateBuilder(args);
builder.Services.AddOutputCache();
var app = builder.Build();
app.UseOutputCache();
配置缓存策略
可以定义命名策略或基于规则的方式控制缓存行为。
全局策略:对所有端点生效 命名策略:按名称引用,灵活分配给特定路由或控制器 匿名策略:直接应用于某个终结点
示例:定义一个缓存 60 秒的命名策略
builder.Services.AddOutputCache(options =>
{
options.AddPolicy(“Default”, context => context.Expire(TimeSpan.FromSeconds(60)));
});
在终结点上应用缓存
有多种方式将缓存策略绑定到具体请求处理逻辑。
Minimal API 中使用app.MapGet(“/time”, () => DateTime.Now.ToString())
.CacheOutput(“Default”);控制器中使用特性[ApiController]
[Route(“[controller]”)]
public class TimeController : ControllerBase
{
[HttpGet]
[OutputCache(PolicyName = “Default”)]
public IActionResult Get() => Ok(DateTime.Now);
}
自定义缓存条件
可基于请求头、查询参数、路径等决定是否参与缓存。
例如:仅当用户未登录且请求为 GET 时缓存
options.AddPolicy(“AnonymousGet”, context =>
{
var isGet = context.HttpContext.Request.Method == “GET”;
var isAuthenticated = context.HttpContext.User.Identity?.IsAuthenticated == true;
if (!isGet || isAuthenticated)
{
context.NoCache();
}
else
{
context.Expire(TimeSpan.FromMinutes(5));
}
});
该机制支持细粒度控制,比如排除某些查询参数、设置 vary headers(如 Vary by Query Keys、Vary by Header)等。
常见配置选项
Expire(TimeSpan):设置过期时间 VaryByQueryKeys(new[] {"id"}):根据查询参数变化缓存 VaryByHeader("Accept-Language"):根据请求头区分缓存版本 NoCache():跳过缓存
例如:根据不同地区语言缓存不同版本
options.AddPolicy(“Localized”, context =>
{
context.VaryByHeader(“Accept-Language”)
.Expire(TimeSpan.FromHours(1));
});基本上就这些。合理配置输出缓存能显著减少服务器负载,加快响应速度。注意避免对个性化内容误用缓存。
以上就是ASP.NET Core 中的输出缓存如何配置?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1440596.html
微信扫一扫
支付宝扫一扫