我在我的webuser控件(.ascx)上使用OutputCache
<%@ OutputCache Duration="1000" VaryByParam="none" %>
Run Code Online (Sandbox Code Playgroud)
我想在接下来的1000秒内保留缓存,但是当我的网站上的特定页面被加载时,我想删除/刷新/刷新缓存.就像,我想在加载MyPage.aspx时清除缓存.我可以在程序上刷新缓存吗?
它只有一个页面是缓存,因此没有用于刷新缓存的paramatrized版本.
感谢您的帮助.
Luk*_*keH 33
您可以使用此VaryByCustom参数.
在您的用户控件中,您将拥有以下内容:
<%@ OutputCache Duration="1000" VaryByParam="None" VaryByCustom="MyKey" %>
Run Code Online (Sandbox Code Playgroud)
然后你将覆盖GetVaryByCustomStringGlobal.asax中的方法,如下所示:
public override string GetVaryByCustomString(HttpContext context, string arg)
{
if (arg == "MyKey")
{
object o = context.Current.Application["MyGuid"];
if (o == null)
{
o = Guid.NewGuid();
context.Current.Application["MyGuid"] = o;
}
return o.ToString();
}
return base.GetVaryByCustomString(context, arg);
}
Run Code Online (Sandbox Code Playgroud)
最后,MyPage.aspx你会这样做:
Application["MyGuid"] = Guid.NewGuid();
Run Code Online (Sandbox Code Playgroud)
这是如何运作的?
每当您的控件被缓存时,它都与一个字符串相关联(GetVaryByCustomString当您的控件的VaryByCustom键传入其中时,从该方法返回的字符串).
无论何时随后使用控件,GetVaryByCustomString都会再次调用.如果返回的字符串与控件的缓存版本匹配,则使用缓存版本.
在我们的例子中,传递"MyKey" GetVaryByCustomString并返回存储的内容Application["MyGuid"].
无论何时MyPage.aspx调用,它都会更改Application["MyGuid"]为新的随机值.
下次使用您的控件时,该GetVaryByCustomString方法将返回新值,并且由于没有与该值关联的控件的缓存版本,因此将重新生成控件.(然后控件将被缓存并与新值相关联,以持续到下一次调用MyPage.aspx等)
这里有一个概述这里.
Jos*_*ger 11
您可以使用HttpResponse.RemoveOutputCacheItem或HttpResponse.AddCacheItemDependency使输出缓存条目无效.
破解一种坚定的方法是一个大锤,但它是完全清除/刷新我发现的应用程序缓存的最简单,最有效的方法.
只需致电:
HttpRuntime.UnloadAppDomain();
Run Code Online (Sandbox Code Playgroud)
这与回收应用程序池具有相同的影响.不适合所有情况,但它肯定会完成工作.
受到其他帖子的启发,以下代码片段OutputCache使用反射成功删除了 ASP.NET 中缓存的每个页面:
public static void ClearOutputCache()
{
var runtimeType = typeof(HttpRuntime);
var ci = runtimeType.GetProperty(
"CacheInternal",
BindingFlags.NonPublic | BindingFlags.Static);
var cache = ci.GetValue(ci, new object[0]);
var cachesInfo = cache.GetType().GetField(
"_caches",
BindingFlags.NonPublic | BindingFlags.Instance);
var cacheEntries = cachesInfo.GetValue(cache);
var outputCacheEntries = new List<object>();
foreach (Object singleCache in cacheEntries as Array)
{
var singleCacheInfo =
singleCache.GetType().GetField("_entries",
BindingFlags.NonPublic | BindingFlags.Instance);
var entries = singleCacheInfo.GetValue(singleCache);
foreach (DictionaryEntry cacheEntry in entries as Hashtable)
{
var cacheEntryInfo = cacheEntry.Value.GetType().GetField("_value",
BindingFlags.NonPublic | BindingFlags.Instance);
var value = cacheEntryInfo.GetValue(cacheEntry.Value);
if (value.GetType().Name == "CachedRawResponse")
{
var key = (string)cacheEntry.Value.GetType().BaseType.GetField("_key", BindingFlags.Instance | BindingFlags.NonPublic).GetValue(cacheEntry.Value);
key = key.Substring(key.IndexOf("/"));
outputCacheEntries.Add(key);
}
}
}
foreach (string key in outputCacheEntries)
{
HttpResponse.RemoveOutputCacheItem(key);
}
}
Run Code Online (Sandbox Code Playgroud)
编辑:如果您在 II6+ 上启用了内核缓存,那么您将需要遵循 Luke 的建议并使用 VaryByCustom 标头,因为清除 ASP.NET 缓存不会影响内核缓存。
OutputCache 存储在 ASP.NET Cache 中,因此您只需调用 Cache.Remove 即可:
List<string> keys = new List<string>();
foreach(string key in HttpRuntime.Cache)
{
keys.Add(key);
}
foreach(string key in keys)
{
Cache.Remove(key);
}
Run Code Online (Sandbox Code Playgroud)
但是,这将删除所有缓存条目,包括代码添加的自定义条目。
| 归档时间: |
|
| 查看次数: |
22610 次 |
| 最近记录: |