Подтвердить что ты не робот

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

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

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

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

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

4b9b3361

Ответ 1

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

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

Ответ 2

Вышеописанное хорошо, если вы знаете, на каких страницах вы хотите очистить кеш. В моем экземпляре (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);
}

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

Очищающий кэш:

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

Надеюсь, что это поможет.

Ответ 3

Использование Response.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.

Ответ 4

В событии загрузки главной страницы напишите следующее:

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

а в кнопке выхода:

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

Ответ 5

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

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

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

Ответ 6

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

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

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

Cache.Remove(key);

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

Ответ 7

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

sqlcachedependency msdn

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

Ответ 8

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