在ASP.NET Core中配置响应缓存需注册Response Caching Middleware并使用[ResponseCache]特性设置缓存策略,如Duration、Location等参数,中间件仅缓存GET或HEAD请求的成功响应,且为内存缓存,不支持分布式场景,需结合Redis或CDN实现共享缓存。

在 ASP.NET Core 中配置响应缓存,主要是通过 Response Caching Middleware 实现,它可以缓存服务器端的响应内容,减少重复请求对后端资源的消耗。要正确启用和使用响应缓存,需要完成以下几个步骤。
要在项目中使用响应缓存,首先需要在 Program.cs 中注册相关服务和中间件:
builder.Services.AddResponseCaching();
// 添加响应缓存服务
var app = builder.Build();
app.UseResponseCaching();
// 确保在调用 UseRouting 之后、UseEndpoints 之前使用中间件
最常见的方式是通过 [ResponseCache] 特性来配置单个控制器或 Action 的缓存策略。这个特性会设置响应头中的 Cache-Control、Expires、Vary 等字段。
示例:
[HttpGet("products")]
[ResponseCache(Duration = 60, Location = ResponseCacheLocation.Any, NoStore = false)]
public IActionResult GetProducts()
{
var products = _productService.GetAll();
return Ok(products);
}
说明:
如果需要更灵活的控制,比如基于请求头或自定义逻辑决定是否缓存,可以结合中间件和手动设置响应头:
HttpContext.Response.GetTypedHeaders().CacheControl = new Microsoft.Net.Http.Headers.CacheControlHeaderValue()
{
Public = true,
MaxAge = TimeSpan.FromSeconds(120)
};
HttpContext.Response.Headers["Vary"] = new string[] { "Accept-Encoding" };
这种方式适合在中间件或 Action 内部动态控制缓存行为。
响应缓存中间件只缓存成功(状态码 200)的 HTTP GET 或 HEAD 请求。以下情况不会缓存:
另外,该中间件是**内存缓存**,不支持分布式场景。如需跨服务器共享缓存,建议结合 Redis 或 CDN 使用。
基本上就这些。合理使用响应缓存能显著提升接口性能,尤其是在数据变化不频繁的场景下。关键是根据业务需求设置合适的 Duration 和 Vary 头。
以上就是ASP.NET Core 中的响应缓存如何配置?的详细内容,更多请关注php中文网其它相关文章!
 
                        
                        每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
 
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号