很早就想写多点关于手艺的东西
一来是为了自身能够更方面的查询,而来固然了更方面人人拉。哈
闲话少说
本日恰好有空就拼集点出来
页面缓存
运用OutputCache指令。
<%@ OutputCache Duration="3600"
Location="Any"
VaryByCustom="browser"
VaryByParam="RequestID" %>
个中Duration和VaryByParam特征是必需的。
Location掌握页面缓存的位置
Location |
寄义 |
Any |
默认值。意味着页面的输出能够缓存在客户端浏览器,缓存在任何“下流”的客户端(如代理服务器),或缓存在Web服务器自身 |
Client |
指明输出缓存只能存储在发出请求的客户端(即浏览器)的当地缓存中 |
Downstream |
指明输出缓存能存储在任何支撑HTTP1.1缓存的装备(如代理服务器)中 |
Server |
指明输出缓存将存储在Web服务器上 |
None |
指明该页面禁用输出缓存 |
Duration许可我们掌握页面在缓存中生存的时刻(单元是秒)
VaryByParam许可我们缓存页面的差别版本。在上面的例子中,VaryByParam设为了RequestID,所以ASP.NET运用RequestID参数的差别值,这些值或者是在HTTP GET的查询字符串中传入,或者是在HTTP POST的参数中传入。能够经由过程搜检RequestID参数的值让应用顺序辨别差别的用户;经由过程在页面的OutputCache指令中安排VaryByParam="RequestID",能够让ASP.NET为每一个用户缓存页面的差别版本。
假如不想依据参数的值缓存页面的不问版本,那末只要把VaryByParam设为none。
也能够请求ASP.NET为每一个能够的参数组合缓存页面的一个版本。为此,可把VaryByParam设为*。
VaryByHeader和VaryByCustom特征与VaryByParam的相似之处在于,它们许可指定什么时刻应建立页面新的缓存版本。
VaryByHeader许可我们依据由分号分开的HTTP头的列表末缓存页面的不向版本。
VaryByCustom当设为browser时,许可我们依据浏览器的称号和主版本信息缓存差别版本。也能够把它设为一个自定义要领的称号,从而完成我们自身的逻辑,掌握缓存的版本。
片断缓存
能够应用用户控件将页面分段,在ascx文件中写入缓存的语句,而不在aspx文件中写缓存语句,如许ASP.NET就能够只缓存ascx片断的输出了。平常像页眉或页脚基本上都是一样的,就不须要从新加载。然则假如个中有动态变化的数据就不能对其举行缓存,由于一旦被缓存后顺序就不会再建立它的实例来更新数据显现,只要比及生存期逾期才行,所以关于这类状况就不适于用页面片断缓存。
注重:
一、注重片断缓存不支撑Location特征;缓存页面片断唯一正当的处所是web服务器。这是由于片断缓存在ASP.NET中是新的功用,所以浏览器和代理服务器不支撑。
二、片断缓存有别的一个在页面缓存中没有的特征——VaryByControl。VaryByControl特征许可指定一个由分号分开的字符串列表,代表用户控件内运用的控件的称号;ASP.NET将针对值的每一个差别的组合生成用户构件的一个缓存版本。
数据缓存
初级API是Cache类,它位于ASP.NET中的System.web.Caching定名空间,能够用它缓存生成很消耗资本的数据。Cache类的运用和Session与Application对象一样简朴。每一个应用顺序只要一个Cache对象——这意味着运用Cache对象存储在缓存中的数据是应用顺序级别的数据。使事变更加简朴的是,Page类的Cache属性使应用顺序的Cache对象实例能在代码中运用。
经由过程Cache对象缓存的数据存储在应用顺序的内存中。这意味着该数据的生存期不会凌驾应用顺序的重启(事实上,这和存储在Application与Session对象中的数据一样,除非运用StateService或SQL State会话形式存储Session数据)。
细致的运用和语法与Session和Application一样。转换返来的时刻须要注重对其举行响应范例的强迫范例转换。
这不是在ASP.NET缓存中增加缓存项的唯一体式格局。Cache对象有两个要领Insert()要领和Add()要领,它们灵活性更高。它们的用法近似,但稍有差别:
Insert()要领用于掩盖ASP.NET缓存中现有的缓存项。
Add()要领只用于在ASP.NET缓存中增加新的缓存项(假如用它掩盖现有的缓存项,则会失利)。
每一个要领都有7个参数,而且两个要领的参数雷同。
在缓存某一项时,能够指定它的相干性,关照ASP.NET该缓存项在缓存中一向保存到某个事宜发作时为止。
相干性值 |
寄义 |
CacheDependency |
许可指定一个文件或缓存键。假如文件发作变化,对象就被删除。假如缓存键发作变化,对象也被删除。 |
DateTime |
这是一个DataTime值,指明缓存数据逾期的时刻(相对逾期时刻) |
TimeSpan |
这是一个时刻距离,指明缓存数据在上一次接见后能够在缓存中保存多长时刻(弹性逾期时刻) |
运用CacheItemPriority来指定缓存数据的优先级,以便在缓存被填满的时刻删除那些优先级低的数据。
优先级值 |
寄义 |
High |
设为此优先级的缓存项是最不能够在内存不足时被删除的 |
AboveNormal |
设为此优先级的缓存项比优先级为Normal或以下的缓存项更优先保存 |
Normal |
设为此优先级的缓存项比优先级为BelowNormal和Low的缓存项更优先保存 |
BelowNormal |
这是倒数第二级的优先级;设为此优先级的缓存项只比优先级设为Low的缓存项更优先保存 |
Low |
设为此优先级的缓存项是最有能够在内存不足时被删除的 |
Default |
缓存项的优先级的默认值是Normal |
NotRemovable |
当缓存项设为此优先级时,是在关照ASP.NET即使是内存不足,也不要从缓存中删除它 |
DateTime dt = new DateTime(DateTime.Now.Year,12,31);
Cache.Add("MembersDataSet",dsMembers,null,
dt,TimeSpan.Zero,
CacheItemPriority.Normal,null);
第一个参数是援用缓存对象的键,第二个参数是要缓存的对象。第三个参数是null(表明没有相干性)。
第四和第五个参数是相对的逾期时刻和弹性的逾期时刻。这里,我们指定缓存应在当前年份的末了一天逾期(dt)。我们想指定没有弹性的逾期时刻,所以第五个参数运用TimeSpan.Zero。第六个参数运用System.Web.Caching.CacheItemPriority罗列中的一个值,把优先级设为Normal。
指定一个5分钟的弹性逾期时刻,没有指定相对逾期时刻
Cache.Add("MembersDataSet",dsMembers,null,
DateTime.MaxValue,TimeSpan.FromMinutes(5),
CacheItemPriority.Normal,null);
增加一个相干性。在这个例子中,逾期时刻也取决于一个文件的修正,即test.xml文件:
CacheDependency dep = new CacheDependency(@"C:/test.xml");
Cache.Add("MembersDataSet",dsMembers,dep,
DateTime.MaxValue,TimeSpan.FromMinutes(5),
CacheItemPriority.Normal,null);
逾期时刻取决于缓存中另一项的修正:
String[] dependencyKeys = new String[1];
dependencyKeys[0] = "MembersChanged";
CacheDependency dependency = new CacheDependency(null, dependencyKeys);
Cache.Add("MembersDataSet",dsMembers,dependency,
DateTime.MaxValue,TimeSpan.Zero,
CacheItemPriority.Normal,null);
末了一个参数是CacheItemRemovedCallback范例的,许可我们在缓存项从缓存中删除时请求关照,能够编写一个自定义的要领(像这里的ItemRemovedCallback()要领),然后在第7个参数中指定该要领:
public void ItemRemovedCallback(String key, Object value, CacheItemRemovedReason reason)
{
}
Cache.Add("MembersDataSet",dsMembers,dependency,
DateTime.MaxValue,TimeSpan.FromMinutes(5),
CacheItemPriority.Normal,
new CacheItemRemovedCallback(this.ItemRemovedCallback));
第一个参数是在缓存中存储缓存项时运用的键,第二个是存储的对象自身,第三个是缓存项删除的缘由。
以上就是浅析asp.net页面缓存手艺 的细致内容,更多请关注ki4网别的相干文章!