ASP缓存类

发布时间:2013-09-19 11:33:46来源:阅读(1596)

    至于缓存的作用,我想我也不用再多说了,它的作用已经很明显,特别是对于信息量非常大或是全数据库页面的网站,他能很好地利用主机的内存资源,加速ASP的执行效率,减轻服务器的负担,而动网在这一方面做得是最突出的,像他现在的dvbbs7.1.0版,更是在缓存的利用上更上一层楼,前后台大多的操作都和缓存有关,而现在动网里用的也就是迷城浪子的缓存类,下面列出动网的三大高手 写的ASP缓存类 
    木鸟写的
    ’********************************************** 
    ’ vbs Cache类 
    ’ 
    ’ 属性valid,是否可用,取值前判断 
    ’ 属性name,cache名,新建对象后赋值 
    ’ 方法add(值,到期时间),设置cache内容 
    ’ 属性value,返回cache内容 
    ’ 属性blempty,是否未设置值 
    ’ 方法makeEmpty,释放内存,测试用 
    ’ 方法equal(变量1),判断cache值是否和变量1相同 
    ’ 方法expires(time),修改过期时间为time 
    ’ 木鸟 2002.12.24 
    ’ http://www.aspsky.net/ 
    ’********************************************** 
    class Cache 
    private obj ’cache内容 
    private expireTime ’过期时间 
    private expireTimeName ’过期时间application名 
    private cacheName ’cache内容application名 
    private path ’uri 
    private sub class_initialize() 
    path=request.servervariables("url") 
    path=left(path,instrRev(path,"/")) 
    end sub 
    private sub class_terminate() 
    end sub 
    public property get blEmpty 
    ’是否为空 
    if isempty(obj) then 
    blEmpty=true 
    else 
    blEmpty=false 
    end if 
    end property 
    public property get valid 
    ’是否可用(过期) 
    if isempty(obj) or not isDate(expireTime) then 
    valid=false 
    elseif CDate(expireTime)valid=false 
    else 
    valid=true 
    end if 
    end property 
    public property let name(str) 
    ’设置cache名 
    cacheName=str & path 
    obj=application(cacheName) 
    expireTimeName=str & "expires" & path 
    expireTime=application(expireTimeName) 
    end property 
    public property let expires(tm) 
    ’重设置过期时间 
    expireTime=tm 
    application.lock 
    application(expireTimeName)=expireTime 
    application.unlock 
    end property 
    public sub add(var,expire) 
    ’赋值 
    if isempty(var) or not isDate(expire) then 
    exit sub 
    end if 
    obj=var 
    expireTime=expire 
    application.lock 
    application(cacheName)=obj 
    application(expireTimeName)=expireTime 
    application.unlock 
    end sub 
    public property get value 
    ’取值 
    if isempty(obj) or not isDate(expireTime) then 
    value=null 
    elseif CDate(expireTime)value=null 
    else 
    value=obj 
    end if 
    end property 
    public sub makeEmpty() 
    ’释放application 
    application.lock 
    application(cacheName)=empty 
    application(expireTimeName)=empty 
    application.unlock 
    obj=empty 
    expireTime=empty 
    end sub 
    public function equal(var2) 
    ’比较 
    if typename(obj)<>typename(var2) then 
    equal=false 
    elseif typename(obj)="Object" then 
    if obj is var2 then 
    equal=true 
    else 
    equal=false 
    end if 
    elseif typename(obj)="Variant()" then 
    if join(obj,"^")=join(var2,"^") then 
    equal=true 
    else 
    equal=false 
    end if 
    else 
    if obj=var2 then 
    equal=true 
    else 
    equal=false 
    end if 
    end if 
    end function 
    end class 

    木鸟 类例子 vbs Cache类
    ’ 
    ’ 属性valid,是否可用,取值前判断 
    ’ 属性name,cache名,新建对象后赋值 
    ’ 方法add(值,到期时间),设置cache内容 
    ’ 属性value,返回cache内容 
    ’ 属性blempty,是否未设置值 
    ’ 方法makeEmpty,释放内存, 
    ’ 方法DelCahe ,删除内存 
    ’ 方法equal(变量1),判断cache值是否和变量1相同 
    ’ 方法expires(time),修改过期时间为time 
    ’ 用法 
    set myCache=New Cache 
    myCache.name="BoardJumpList" ’定义缓存名 
    if myCache.valid then ’判断是否可用(包括过期,与是否为空值) 
    response.write myCache.value ’输出 
    else 
    ................ 
    BoardJumpList=xxx 
    myCache.add BoardJumpList,dateadd("n",60,now) ’写入缓存 xxx.add 内容,过期时间 
    response.write BoardJumpList ’输出 
    end if 
    myCache.makeEmpty() 释放内存 
    mycache.DelCahe() 删除缓存 
    (二)迷城浪子写的 Class Cls_Cache 



    Rem ==================使用说明====================
    Rem = 本类模块是动网先锋原创,作者:迷城浪子。如采用本类模块,请不要去掉这个说明。这段注释不会影响执行的速度。
    Rem = 作用:缓存和缓存管理类
    Rem = 公有变量:Reloadtime 过期时间(单位为分钟)缺省值为14400
    Rem = MaxCount 缓存对象的最大值,超过则自动删除使用次数少的对象。缺省值为300 
    Rem = CacheName 缓存组的总名称,缺省值为"Dvbbs",如果一个站点中有超过一个缓存组,则需要外部改变这个值。 
    Rem = 属性:Name 定义缓存对象名称,只写属性。 
    Rem = 属性:value 读取和写入缓存数据。 
    Rem = 函数:ObjIsEmpty()判断当前缓存是否过期。 
    Rem = 方法:DelCahe(MyCaheName)手工删除一个缓存对象,参数是缓存对象的名称。
    Rem ======================== 
    Public Reloadtime,MaxCount,CacheName 
    Private LocalCacheName,CacheData,DelCount 
    Private Sub Class_Initialize() 
    Reloadtime=14400 
    CacheName="Dvbbs" 
    End Sub 
    Private Sub SetCache(SetName,NewValue) 
    Application.Lock 
    Application(SetName) = NewValue 
    Application.unLock 
    End Sub 
    Private Sub makeEmpty(SetName) 
    Application.Lock 
    Application(SetName) = Empty 
    Application.unLock 
    End Sub 
    Public Property Let Name(ByVal vNewValue) 
    LocalCacheName=LCase(vNewValue) 
    End Property 
    Public Property Let Value(ByVal vNewValue) 
    If LocalCacheName<>"" Then 
    CacheData=Application(CacheName&"_"&LocalCacheName) 
    If IsArray(CacheData) Then 
    CacheData(0)=vNewValue 
    CacheData(1)=Now() 
    Else 
    ReDim CacheData(2) 
    CacheData(0)=vNewValue 
    CacheData(1)=Now() 
    End If 
    SetCache CacheName&"_"&LocalCacheName,CacheData 
    Else 
    Err.Raise vbObjectError + 1, "DvbbsCacheServer", " please change the CacheName." 
    End If 
    End Property 
    Public Property Get Value() 
    If LocalCacheName<>"" Then 
    CacheData=Application(CacheName&"_"&LocalCacheName) 
    If IsArray(CacheData) Then 
    Value=CacheData(0) 
    Else 
    Err.Raise vbObjectError + 1, "DvbbsCacheServer", " The CacheData Is Empty." 
    End If 
    Else 
    Err.Raise vbObjectError + 1, "DvbbsCacheServer", " please change the CacheName." 
    End If 
    End Property 
    Public Function ObjIsEmpty() 
    ObjIsEmpty=True 
    CacheData=Application(CacheName&"_"&LocalCacheName) 
    If Not IsArray(CacheData) Then Exit Function 
    If Not IsDate(CacheData(1)) Then Exit Function 
    If DateDiff("s",CDate(CacheData(1)),Now()) < 60*Reloadtime Then 
    ObjIsEmpty=False 
    End If 
    End Function 
    Public Sub DelCahe(MyCaheName) 
    makeEmpty(CacheName&"_"&MyCaheName) 
    End Sub 
    End Class 

    迷城浪子 类例子



    Set WydCache=New Cls_Cache 
    WydCache.Reloadtime=0.5 ’定义过期时间 (以分钟为单会) 
    WydCache.CacheName="pages" ’定义缓存名 
    IF WydCache.ObjIsEmpty() Then ’’判断是否可用(包括过期,与是否为空值) 
    Response.write WydCache.Value 
    Else 
    .................. 
    BoardJumpList=xxx 
    WydCache.Value=BoardJumpList ’写入内容 
    Response.write BoardJumpList 
    End if 

    mycache.DelCahe("缓存名") 删除缓存 


    (三)slightboy 写的



    ’========================
    ’clsCache.asp 
    ’========================
    ’== begin : 2004-6-26 21:51:47 
    ’== copyright : slightboy (C)1998-2004 
    ’== email : slightboy@msn.com 
    ’======================== 
    ’========================
    ’ Dim Application(2) 
    ’ Application(0) Counter 计数器 
    ’ Application(1) dateTime 放置时间 
    ’ Application(2) Content 缓存内容 

    Public PREFIX 
    Public PREFIX_LENGTH 

    Private Sub Class_Initialize() 
    PREFIX = "Cached:" 
    PREFIX_LENGTH = 7 
    End Sub 
    Private Sub Class_Terminate 
    End Sub 
    ’ 设置变量 
    Public Property Let Cache(ByRef Key, ByRef Content) 
    Dim Item(2) 
    Item(0) = 0 
    Item(1) = Now() 
    IF (IsObject(Content)) Then 
    Set Item(2) = Content 
    Else 
    Item(2) = Content 
    End IF 
    Application.Unlock 
    Application(PREFIX & Key) = Item 
    Application.Lock 
    End Property 
    ’ 取出变量 计数器++ 
    Public Property Get Cache(ByRef Key) 
    Dim Item 
    Item = Application(PREFIX & Key) 
    IF (IsArray(Item)) Then 
    IF (IsObject(Item)) Then 
    Set Cache = Item(2) 
    Else 
    Cache = Item(2) 
    End IF 
    Application(PREFIX & Key)(0) = Application(PREFIX & Key)(0) + 1 
    Else 
    Cache = Empty 
    End IF 
    End Property 
    ’ 检查缓存对象是否存在 
    Public Property Get Exists(ByRef Key) 
    Dim Item 
    Item = Application(PREFIX & Key) 
    IF (IsArray(Item)) Then 
    Exists = True 
    Else 
    Exists = False 
    End IF 
    End Property 
    ’ 得到计数器数值 
    Public Property Get Counter(ByRef Key) 
    Dim Item 
    Item = Application(PREFIX & Key) 
    IF (IsArray(Item)) Then 
    Counter = Item(0) 
    End IF 
    End Property 

    ’ 设置计数器时间 
    Public Property Let dateTime(ByRef Key, ByRef SetdateTime) 
    Dim Item 
    Item = Application(PREFIX & Key) 
    IF (IsArray(Item)) Then 
    Item(1) = SetdateTime 
    End IF 
    End Property 
    ’ 得到计数器时间 
    Public Property Get dateTime(ByRef Key) 
    Dim Item 
    Item = Application(PREFIX & Key) 
    IF (IsArray(Item)) Then 
    dateTime = Item(1) 
    End IF 
    End Property 

    ’ 重置计数器 
    Public Sub ResetCounter() 
    Dim Key 
    Dim Item 
    Application.Unlock 
    For Each Key in Application.Contents 
    IF (Left(Key, PREFIX_LENGTH) = PREFIX) Then 
    Item = Application(Key) 
    Item(0) = 0 
    Application(Key) = Item 
    End IF 
    Next 
    Application.Lock 
    End Sub 
    ’ 删除某以缓存 
    Public Sub Clear(ByRef Key) 
    Application.Contents.Remove(PREFIX & Key) 
    End Sub 
    ’ 清空没有使用的缓存 
    Public Sub ClearUnused() 
    Dim Key, Keys, KeyLength, KeyIndex 
    For Each Key in Application.Contents 
    IF (Left(Key, PREFIX_LENGTH) = PREFIX) Then 
    IF (Application(Key)(0) = 0) Then 
    Keys = Keys & VBNewLine & Key 
    End IF 
    End IF 
    Next 
    Keys = Split(Keys, VBNewLine) 
    KeyLength = UBound(Keys) 
    Application.Unlock 
    For KeyIndex = 1 To KeyLength 
    Application.Contents.Remove(Keys(KeyIndex)) 
    Next 
    Application.Lock 
    End Sub 
    ’ 清空所有缓存 
    Public Sub ClearAll() 
    Dim Key, Keys, KeyLength, KeyIndex 
    For Each Key in Application.Contents 
    IF (Left(Key, PREFIX_LENGTH) = PREFIX) Then 
    Keys = Keys & VBNewLine & Key 
    End IF 
    Next 
    Keys = Split(Keys, VBNewLine) 
    KeyLength = UBound(Keys) 
    Application.Unlock 
    For KeyIndex = 1 To KeyLength 
    Application.Contents.Remove(Keys(KeyIndex)) 
    Next 
    Application.Lock 
    End Sub 

    End Class 


    slightboyn 类例子



    Set Wyd=New JayCache 
    Wyd.dateTime("Page")=时 间 
    If Wyd.Exists("Page") Then 
    Response.write Wyd.Cache("Page") ’输出 
    Else 
    Wyd.Cache("Page")=xxx 写入 
    Responxe.write xxx 
    End IF 
    Wyd.Clear("page")’删除缓存

关键字

上一篇: MySQL入门指南

下一篇: 一个简单ASP分页