Очистка Кэша страниц в ASP.NET
для моего блога я хочу использовать кэш вывода, чтобы сохранить кэшированную версию определенным после примерно 10 минут, и это нормально...
<%@OutputCache Duration="600" VaryByParam="*" %>
однако, если кто-то публикует комментарий, Я хочу очистить кэш, чтобы страница была обновлена и комментарий можно было увидеть.
Как это сделать в ASP.Net C#?
8 ответов
выше, если вы знаете, какие страницы вы хотите очистить кэш для. В моем случае (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?
таким образом, вы не реализуете пользовательский код очистки кэша и просто обновляете кэш по мере изменения содержимого в БД?