(1) MVC BaseController: Controller内
protected override void Initialize(System.Web.Routing.RequestContext requestContext) { List<string> keys = new List<string>(); // retrieve application Cache enumerator IDictionaryEnumerator enumerator = HttpRuntime.Cache.GetEnumerator(); // copy all keys that currently exist in Cache while (enumerator.MoveNext()) { keys.Add(enumerator.Key.ToString()); } // delete every key from cache for (int i = 0; i < keys.Count; i++) { HttpRuntime.Cache.Remove(keys[i]); } }
或
public ActionResult Index() { HttpContext.Response.ContentType = "text/plain"; HttpContext.Response.Buffer = true; HttpContext.Response.ExpiresAbsolute = DateTime.Now.AddDays(-1); HttpContext.Response.AddHeader("pragma", "no-cache"); HttpContext.Response.AddHeader("cache-control", "private"); HttpContext.Response.CacheControl = "no-cache"; }
或
[OutputCache(Duration = 0, Location = OutputCacheLocation.Client)] public ActionResult Index() { var columnList = new List<ColumnDisplayModels>(); var viewModel = new ReportModels { ReportId = 1, ReportName = "", ReportSql = "", ReportColumns = columnList }; return View(viewModel); }
(2) HTML方法
<HEAD> <META HTTP-EQUIV="Pragma" CONTENT="no-cache"> <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache"> <META HTTP-EQUIV="Expires" CONTENT="0"> </HEAD>
(3) 重新调用原页面的时候在给页面传一个参数: href="****.ASPX?random()"
ASPX:
方法1 aspx页的顶部加一句声明<%@ OutputCache Duration="60" VaryByParam="none" %>
方法2 Page_Load事件中加上
Context.Response.Cache.SetCacheability(HttpCacheability.NoCache);
方法3
在请求网址后面加一个时间戳的参数。
xxx.aspx?d=aaa
aaa用datetime.now
Web.config中配置缓存:
一、web.config 配置页面输出缓存
<system.web> <caching> <outputCacheSettings> <outputCacheProfiles> <add name="pageCache" duration="60" varyByParam="none" enabled ="true"/> </outputCacheProfiles> </outputCacheSettings> </caching> </system.web>
页面调用:
(1)Duration属性
该属性指定页或用户控件进行缓存的时间,以秒为单位。在页或用户控件上设置该属性为来自对象的 HTTP 响应建立了一个过期策略,并将自动缓存页或用户控件输出。
例如:设置页或用户控件进行输出缓存的持续时间为100秒。代码如下:
<%@ OutputCache Duration="100" VaryByParam="none" %>
注意:这是必选属性。如果未包含该属性,将出现分析器错误。
(2)VaryByParam属性
该属性为分号分隔的字符串列表,用于使输出缓存发生变化。默认情况下,这些字符串与随GET方法发送的查询字符串值对应,或与使用POST方法发送的参数对应。将该属性设置为多个参数时,对于每个指定参数组合,输出缓存都包含一个不同版本的请求文档。可能的值包括none、星号 (*)以及任何有效的查询字符串或POST参数名称。
注意:在ASP.NET页和用户控件上使用@OutputCache指令时,需要包含VaryByParam属性或VaryByControl属性。如果没有包含VaryByParam属性或VaryByControl属性,则发生分析器错误。如果不希望通过指定参数来改变缓存内容,可将VaryByParam属性值设置为none。如果希望通过所有的参数值改变输出缓存,可将属性设置为星号(*)。
二、web.config 配置 asp.net 应用程序全局缓存配置
<cache disableMemoryCollection = "false" //获取或设置一个值,该值指示是否当计算机处于内存压力下时是否禁止执行缓存内存回收
disableExpiration = "false" //获取或设置一个值,该值指示是否禁用缓存过期。如果禁用,则缓存项不会过期,并且不会对过期缓存项执行后台清理。
privateBytesLimit = "20971520" //获取或设置一个值,该值指示在缓存开始刷新过期项并尝试回收内存之前应用程序的最大专用字节大小。 此限制同时包括缓存所使用的内存量以及运行应用程序的正常内存开销。 如果设置为零,则指示 ASP.NET 将使用自己的试探法确定何时开始回收内存。
percentagePhysicalMemoryUsedLimit = 60"
privateBytesPollTime = "00:01:00"/> //获取或设置一个值,该值指示两次轮询应用程序专用字节内存使用量之间的时间间隔。
备注:给页面统一加上缓存
public class basepage : System.Web.UI.Page { protected override void OnInit(EventArgs e) { base.OnInit(e); this.InitOutputCache(1000, null, null, OutputCacheLocation.ServerAndClient, "*"); } }
华赐软件: www.huacisoft.com
C#开源社区: www.opencsharp.net
清泓美肤苑: 清泓美肤苑
Html5网站后台: Bootstrap3+html3+div+css3
Ajax在解决缓存时有三种办法。
1、加时间戮
对于一个浏览器,你的第一次点击是会调用rpc请求的, 但是你再用同一个浏览器提交表单的时候, rpc不会被提交, 因为参数一样, 这个可能是ajax的XMLHttpRequest对象的问题, 如设置了时间间隔了,实际上是(new ActiveXObject("Microsoft.XMLHTTP"))所以, 在实际操作的时候, 给rpc的参数传递一个没有用的guid= new Date().getTime()
一个时间戳 ,以保证每次的点击事件都会激发rpc请求, 因为这样的参数(或者说url)是不一样的。
为什么要把时间戳追加到目标url?
在某些情况下, 有些浏览器会把多个XMLHttpRequest请求的结果缓存在同一个url。如果对每个请求的响应不同,这就会带来不好的结果。把当前时间戳追加到url的最后,就能确保url的唯一性,从而避免浏览器的缓存结果。
2、在要异步获取的页面中写一段禁止缓存的代码:
Response.Buffer =True
Response.ExpiresAbsolute =Now() - 1
Response.Expires=0
Response.CacheControl="no-cache"
3、在ajax发送请求前加上xmlHTTP.setRequestHeader("If-Modified-Since","0");可以禁止缓存
xmlHTTP.open("get", URL, true);
xmlHTTP.onreadystatechange = callHTML;
xmlHTTP.setRequestHeader("If-Modified-Since","0");
xmlHTTP.send();
<%
HttpContext.Current.Response.Buffer = true;
HttpContext.Current.Response.Expires = 0;
HttpContext.Current.Response.ExpiresAbsolute = DateTime.Now.AddDays(-1);
HttpContext.Current.Response.AddHeader("pragma", "no-cache");
HttpContext.Current.Response.AddHeader("cache-control", "private");
HttpContext.Current.Response.CacheControl = "no-cache";
%>