ASP.NET Cache支持的三种类型分别是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
ASP.NET Cache支持三种类型
想写一个技术快速概述,可能写得太多了。技术概略的目的是以最快最简单的方式描述出技术要点,也是我希望的最有效率的知识传播方式。
1. 页面/控件cache
2. 应用程序级cache
3. 浏览器客户端cache
从实现方式来看,ASP.NET Cache中的页面/控件cache和应用程序级cache都是存放在服务器内存里面的,随着内存的紧张程度,这些内容有可能在失效之前被提前删除。(cache的特性决定这些内容是可以放心得删除掉的)。浏览器客户端的cache是存放在客户端浏览器的cache里面 ,比如IE的临时文件夹就是起的cache的作用。每次用户请求一个页面的时候,浏览器会先从cache里面去查找一下有没有符合要求的还没有过期的cache内容,如果有的话就从cache里面直接读取跳过网络传输。
下面演示一下在ASP.NET里面具体的写法:
1. ASP.NET Cache中的页面/控件cache可以申明在aspx,ascx文件里面,也可以在code behind里面作出申明。
〈 %@ OutputCache Duration="#ofseconds" Location="Any | Client | Downstream | Server | None | ServerAndClient " Shared="True | False" VaryByControl="controlname" VaryByCustom="browser | customstring" VaryByHeader="headers" VaryByParam="parametername" CacheProfile="cache profile name | ''" NoStore="true | false" SqlDependency="database/table name pair | CommandNotification" % 〉
主要的参数是:
Duration: cache有效的时间,单位秒
Shared:只对控件有效,在控件可以同时应用与多个页面的时候,多个页面是否可以共享这一个cache而不用每个页面维护自己对这个控件的cache。
VaryByControl:cache随控件的ID变化
VaryByCustom:cache随用户自定义的一个变量来变化,该变量是在这里指定,然后应该在Global.ascx里面实现:
public override string GetVaryByCustomString ( HttpContext context, string custom )
该声明的custom参数就是在OutPutcache里面申明的变量。通过在这个函数里面对不同的custom参数返回不同的字符串值来表示不同的cache内容。
VaryByHeader, VaryByParam,CacheProfile也是设置不同的cache版本的。
NoStore表示不允许把cache的内容写到内存以外其它的存储设备上,这是对安全性比较高的内容的需要。
SqlDependency是和数据库相关的。
2. ASP.NET Cache中的应用程序级cache
只可以在code behind里面获得,特点是可以实现自己需要的任何cache逻辑。
可以通过Page.Cache获得,类的名字是System.Web.Caching.Cache
3. ASP.NET Cache中的浏览器客户端cache
只可以在codebehind里面获得,可以通过Response.Cache来指定,这是一个HttpCachePolicy对象。
另外: 可以指定一个TimeSpan作为cache的时间,不用每次来折算到秒。
publicTimeSpan(longticks); publicTimeSpan(inthours,intminutes,intseconds); publicTimeSpan(intdays,inthours, intminutes,intseconds); publicTimeSpan(intdays,inthours, intminutes,intseconds,intmilliseconds);
如果要cache保留一个小时1分1秒,可以直接
new TimeSpan(1,1,1)
而不用先计算
1小时1分1秒=3600+60+1=3661秒,然后在传入3661作为有效期。
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。