Ответ 1
Я нашел ответ, который я искал:
HttpResponse.RemoveOutputCacheItem("/caching/CacheForever.aspx");
В моем блоге я хочу использовать выходной кэш, чтобы сохранить кешированную версию суточного сообщения в течение 10 минут, и это прекрасно...
<%@OutputCache Duration="600" VaryByParam="*" %>
Однако, если кто-то отправляет комментарий, я хочу очистить кеш, чтобы страница обновилась, и комментарий можно увидеть.
Как это сделать в ASP.Net С#?
Я нашел ответ, который я искал:
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);
}
Малая настройка: У меня есть помощник, который добавляет "флэш-сообщения" (сообщения об ошибках, сообщения об успешном завершении - "Этот элемент успешно сохранен" и т.д.). Чтобы избежать появления флеш-сообщения на каждом последующем GET, мне пришлось сделать недействительным после записи флеш-сообщения.
Очищающий кэш:
HttpRuntime.Cache.Insert("Pages", DateTime.Now);
Надеюсь, что это поможет.
Использование 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.
В событии загрузки главной страницы напишите следующее:
Response.Cache.SetExpires(DateTime.UtcNow.AddMinutes(-1));
Response.Cache.SetCacheability(HttpCacheability.NoCache);
Response.Cache.SetNoStore();
а в кнопке выхода:
Session.Abandon();
Session.Clear();
Хм. Вы можете указать атрибут VaryByCustom для элемента OutputCache. Значение этого параметра передается как параметр метода GetVaryByCustomString, который можно реализовать в global.asax. Значение, возвращаемое этим методом, используется как индекс в кэшированных элементах - если вы возвращаете количество комментариев на странице, например, каждый раз, когда добавляется комментарий, новая страница будет кэшироваться.
Предостережение заключается в том, что это фактически не очищает кеш. Если запись в блоге получает интенсивное использование комментариев, ваш кеш может взорваться по размеру с помощью этого метода.
В качестве альтернативы вы можете реализовать не изменяемые биты страницы (навигацию, объявления, фактическую запись в блоге) в качестве пользовательских элементов управления и реализовать частичное кэширование страниц для каждого из этих элементов управления пользователя.
Если вы изменяете "*" только на параметры, к которым кеш должен меняться (PostID?), вы можете сделать что-то вроде этого:
//add dependency
string key = "post.aspx?id=" + PostID.ToString();
Cache[key] = new object();
Response.AddCacheItemDependency(key);
и когда кто-то добавляет комментарий...
Cache.Remove(key);
Я предполагаю, что это сработает даже с VaryByParam *, поскольку все запросы будут привязаны к одной и той же зависимости кэша.
почему бы не использовать sqlcachedependency в таблице posts?
Таким образом, вы не внедряете пользовательский код очистки кэша и просто обновляете кеш при изменении содержимого в db?
HttpRuntime.Close()
.. Я пробую весь метод, и это единственное, что работает для меня