如何在ASP.NET核心rc2中禁用浏览器缓存?

Dav*_*nsa 23 asp.net asp.net-core-mvc

我尝试过这个中间件,但浏览器仍在保存文件.

我希望用户将始终获得js和css文件的最新版本.

public void Configure(IApplicationBuilder app)
{
    app.UseSession();
    app.UseDefaultFiles();
    app.UseStaticFiles(new StaticFileOptions
    {
        OnPrepareResponse = context =>
            context.Context.Response.Headers.Add("Cache-Control", "no-cache")
    });
}
Run Code Online (Sandbox Code Playgroud)

Men*_*tor 30

禁用ASP.NET核心中的浏览器缓存:

public class HomeController : Controller
{
    [ResponseCache(NoStore =true, Location =ResponseCacheLocation.None)]
    public IActionResult Index()
    {
        return View();
    }
}
Run Code Online (Sandbox Code Playgroud)


Wil*_*Ray 20

尝试添加Expires标题:

app.UseStaticFiles(new StaticFileOptions()
{
    OnPrepareResponse = context =>
    {
        context.Context.Response.Headers.Add("Cache-Control", "no-cache, no-store");
        context.Context.Response.Headers.Add("Expires", "-1");
    }
});
Run Code Online (Sandbox Code Playgroud)

另一种方法是添加一个查询字符串,该查询字符串会在开发过程中更改为您的请求的末尾.在这种情况下不需要中间件.

<environment names="Development">
    <link rel="stylesheet" href="~/lib/bootstrap/dist/css/bootstrap.css?@DateTime.Now.Ticks" />
    <link rel="stylesheet" href="~/css/site.css?@DateTime.Now.Ticks" />
</environment>
Run Code Online (Sandbox Code Playgroud)

  • 如果你执行 Headers.Add(,那么如果中间件已经添加了标头,它将失败,因此,使用 Response.Headers["Cache-Control"] = "no-cache, no-store, Must-revalidate, max-age =0”;等等 (5认同)

Mus*_*eas 9

另一种方法是使用ASP-Attribute链接你的文件时_Layout.cshtml使用asp-append-version你将在每次文件更改时添加一个新的哈希,所以写:

<script src="~/js/minime.js" asp-append-version="true"></script>
Run Code Online (Sandbox Code Playgroud)

最终会导致:

<script src="/js/minime.js?v=Ynfdc1vuMOWZFfqTjfN34c2azo3XiIfgfE-bba1"></script>` 
Run Code Online (Sandbox Code Playgroud)

所以你得到了缓存和开箱即用的最新版本.