NOTE: Apart from
(and even then it's questionable, I'm Scottish). These are machine translated in languages I don't read. If they're terrible please contact me.
You can see how this translation was done in this article.
Saturday, 07 September 2024
//2 minute read
缓存是一种重要技术,既可以通过更快地装载内容来改进用户经验,又可以减少服务器上的负担。 在本篇文章中,我将教你如何使用 ASP.NET Core 和 HTMX 的内置缓存功能 来隐藏客户端的内容。
[技选委
在ASP.NET核心部分,提供两类Caching
要在 ASP.NET Core 中设置这些功能, 您需要在您的 ASP. NET Core 中添加一些服务 Program.cs
文件文件
builder.Services.AddResponseCaching();
app.UseResponseCaching();
services.AddOutputCache();
app.UseOutputCache();
同时也有可能在您的 Program.cs
通常有点不灵活(尤其是我发现使用HTMX要求时)。 您可以在您的控制器动作中,通过使用 ResponseCache
属性。
[ResponseCache(Duration = 300, VaryByHeader = "hx-request", VaryByQueryKeys = new[] {"page", "pageSize"}, Location = ResponseCacheLocation.Any)]
这将缓存响应300秒, 并更改缓存 。 hx-request
页眉和页眉 page
和 pageSize
查询参数。 我们还在设置 Location
至 Any
这意味着反应可以隐藏在客户、中间代理服务器或两者上。
在这里 hx-request
标题是 HTMX 随每项请求发送的页眉 。 这很重要, 因为它允许您根据 HTMX 请求或普通请求 以不同的方式隐藏响应 。
这是我们的现在 Index
动作方法。 Youcan 查看我们是否接受页面和页面 ResponseCache
属性。 这意味着这些密钥将回应“索引”并储存基于这些密钥的不同内容。
我们也在《行动行动》中 if(Request.IsHtmx())
这是基于 HTMX.Net 软件包 并进行基本核查,以核查 hx-request
我们用来更改缓存的页头 。 在此,如果HTMX提出要求,我们只提出部分意见。
public async Task<IActionResult> Index(int page = 1,int pageSize = 5)
{
var authenticateResult = GetUserInfo();
var posts =await blogService.GetPosts(page, pageSize);
posts.LinkUrl= Url.Action("Index", "Home");
if (Request.IsHtmx())
{
return PartialView("_BlogSummaryList", posts);
}
var indexPageViewModel = new IndexPageViewModel
{
Posts = posts, Authenticated = authenticateResult.LoggedIn, Name = authenticateResult.Name,
AvatarUrl = authenticateResult.AvatarUrl
};
return View(indexPageViewModel);
}
输出缓存是服务器的侧面, 相当于响应缓存 。 它会缓存控制器动作的输出 。 从本质上说,网络服务器储存请求的结果,并供日后请求使用。
[OutputCache(Duration = 3600,VaryByHeaderNames = new[] {"hx-request"},VaryByQueryKeys = new[] {"page", "pageSize"})]
在这里,我们正在缓存控制器动作的输出 3600秒 并更改缓存 hx-request
页眉和页眉 page
和 pageSize
查询参数。
当我们将数据服务器的侧面储存相当长的时间( 日志仅以 docker 推来更新) 时, 时间定得比回应缓存要长; 对我们的情况来说, 它实际上可能是无限的, 但是 3600 秒是一个很好的折中方案 。
和"反应缓存"一样 我们用的是 hx-request
标题根据请求是否来自 HTMX 来更改缓存 。
ASP.NET核心还内置支持缓存静态文件。 这样做的方式是确定 Cache-Control
回复页头 。 你可以把这个设置在你的 Program.cs
文件。
请注意,这里的顺序非常重要。 如果您的静态文件需要授权支持, 您应该移动 UseAuthorization
之前的中继器件 UseStaticFiles
中间软件。 TH 使用HttpsRedirection 中间软件也应该在使用静态文件的中间软件之前, 如果您依赖此特性 。
app.UseHttpsRedirection();
var cacheMaxAgeOneWeek = (60 * 60 * 24 * 7).ToString();
app.UseStaticFiles(new StaticFileOptions
{
OnPrepareResponse = ctx =>
{
ctx.Context.Response.Headers.Append(
"Cache-Control", $"public, max-age={cacheMaxAgeOneWeek}");
}
});
app.UseRouting();
app.UseCors("AllowMostlylucid");
app.UseAuthentication();
app.UseAuthorization();
Caching是提高您应用程序性能的有力工具。 使用 ASP.NET Core 的内置缓存功能, 您可以很容易地在客户端或服务器端缓存内容 。 通过使用 HTMX, 您可以在客户端隐藏内容, 并提供部分视图来改善用户体验 。