Очистка Кэша страниц в ASP.NET

для моего блога я хочу использовать кэш вывода, чтобы сохранить кэшированную версию определенным после примерно 10 минут, и это нормально...

<%@OutputCache Duration="600" VaryByParam="*" %>

однако, если кто-то публикует комментарий, Я хочу очистить кэш, чтобы страница была обновлена и комментарий можно было увидеть.

Как это сделать в ASP.Net C#?

8 ответов


Я нашел ответ, который искал:

HttpResponse.RemoveOutputCacheItem("/caching/CacheForever.aspx");

выше, если вы знаете, какие страницы вы хотите очистить кэш для. В моем случае (ASP.NET MVC) я ссылался на одни и те же данные со всего мира. Поэтому, когда я сделал [save], я хотел очистить сайт кэша. Вот что сработало для меня:http://aspalliance.com/668

Это делается в контексте фильтра OnActionExecuting. Это может быть так же легко сделано путем переопределения OnActionExecuting в BaseController или что-то.

HttpContextBase httpContext = filterContext.HttpContext;
httpContext.Response.AddCacheItemDependency("Pages");

настройка:

protected void Application_Start()
{
    HttpRuntime.Cache.Insert("Pages", DateTime.Now);
}

Незначительные Настройки: У меня есть помощник, который добавляет "flash - сообщения" (сообщения об ошибках, сообщения об успехе - "этот элемент успешно сохранен" и т. д.). Чтобы избежать появления flash-сообщения на каждом последующем GET, мне пришлось аннулировать после написания flash-сообщения.

Очистка Кэша:

HttpRuntime.Cache.Insert("Pages", DateTime.Now);

надеюсь, что это помогает.


Используя Ответ.AddCacheItemDependency, чтобы очистить все выходные данные.

  public class Page : System.Web.UI.Page
  {
    protected override void OnLoad(EventArgs e)
    {
        try
        {
            string cacheKey = "cacheKey";
            object cache = HttpContext.Current.Cache[cacheKey];
            if (cache == null)
            {
              HttpContext.Current.Cache[cacheKey] = DateTime.UtcNow.ToString();
            }

            Response.AddCacheItemDependency(cacheKey);
        }
        catch (Exception ex)
        {
            throw new SystemException(ex.Message);
        }

        base.OnLoad(e);
    }     
 }



  // Clear All OutPutCache Method    

    public void ClearAllOutPutCache()
    {
        string cacheKey = "cacheKey";
        HttpContext.Cache.Remove(cacheKey);
    }

Это также можно использовать в ASP.NET MVC OutputCachedPage.


на главной странице load event, пожалуйста, напишите следующее:

Response.Cache.SetExpires(DateTime.UtcNow.AddMinutes(-1));
Response.Cache.SetCacheability(HttpCacheability.NoCache);
Response.Cache.SetNoStore();

и в выход кнопки:

Session.Abandon();
Session.Clear();

Мда. В элементе OutputCache можно указать атрибут VaryByCustom. Значение этого передается в качестве параметра методу GetVaryByCustomString, который можно реализовать в global.асакс. Значение, возвращаемое этим методом, используется в качестве индекса в кэшированные элементы - если вы возвращаете количество комментариев на странице, например, каждый раз при добавлении комментария новая страница будет кэшироваться.

нюанс в том, что это не реально очистить кэш. Если запись в блоге получает интенсивное использование комментариев, ваш кэш может взорваться в размере с помощью этого метода.

кроме того, вы можете реализовать неизменяемые биты страницы (навигация, объявления, фактическая запись в блоге) в качестве пользовательских элементов управления и реализовать частичное кэширование страниц на каждом из этих пользовательских элементов управления.


Если вы измените " * " только на параметры, кэш должен отличаться (PostID?) вы можете сделать что-то вроде этого:

//add dependency
string key = "post.aspx?id=" + PostID.ToString();
Cache[key] = new object();
Response.AddCacheItemDependency(key);

и когда кто-то добавляет комментарий...

Cache.Remove(key);

Я думаю, это будет работать даже с VaryByParam *, так как все запросы будут привязаны к одной и той же зависимости кэша.


Почему бы не использовать sqlcachedependency в таблице posts?

sqlcachedependency msdn

таким образом, вы не реализуете пользовательский код очистки кэша и просто обновляете кэш по мере изменения содержимого в БД?


HttpRuntime.Close() .. Я пробую все методы, и это единственное, что работает для меня