• 注册
  • 关于作者
    企业认证:趣记站长
    关注 6 粉丝 4 喜欢 9 内容 992
    江西省·南昌市
    聊天 送礼
    • 查看作者
    • 在ASP中模拟.NET下的cache技术

        为了提高网站首页的性能,首页凡是需要调用数据库显示数据的地方都会先试图从缓存中调用数据,如果缓存中没有可用数据再打开数据库取出记录集,为了让页面显示数据和数据库在一定时间内同步,我们把缓存的过期时间设置成30秒。

        声明:缓存管理类出自于动网论坛7.0

        注意:最好不要在缓存里直接缓存带状态的对象和MTA模式的对象,比如说直接缓存记录集或者数据库链接对象等。

      <%

      Sub ShowRsArr(rsArr)

       '用表格显示记录集getrows生成的数组的表结构

       '

       Response.Write "<table width=100% border=0 cellspacing=0 cellpadding=0>"

       If Not IsEmpty(rsArr) Then

        For y=0 To Ubound(rsArr,2)

         Response.Write"<tr>"

         for x=0 to Ubound(rsArr,1)

          Response.Write "<td>"&rsArr(x,y)&"</td>"

         next

         Response.Write"</tr>"

        next

       Else

        Response.Write "<tr>"

        Response.Write "<td colspan="&rs.fields.count-1&">No Records</td>"

        Response.Write "</tr>"

       End If

       Response.Write "</table>"

      End Sub

      Class Cls_Cache

      Rem ==================使用说明=================================================================================

      Rem = 本类模块是动网先锋原创,作者:迷城浪子。如采用本类模块,

      ASP远程注册自己的组件
      ASP错误处理,ASP网站防范黑客技巧,巧用ASP技术保护DHTML源代码,用ASP取出HTML里面的图片地址的函数,ASP实现网页打开任何类型文件都保存,ASP木马Webshell安全解决办案,几招让你的网站免受采集之苦,ASP使用MYSQL数据库全攻略,Ad Rotator 组件参考,在Asp中使用存储过程数值类型值,asp防止同时登陆的问题,使用ASP重启服务器,在ASP程序中实现数据库事务控制,深入理解ASP中FSO的神奇功能,Asp中一些FSO方面的函数,用ASP编程实现网络内容快速查找,ASP实现文件直接下载,Adodb.Stream 组件的使用说明,全国省市县无刷新多级关联菜单,ASP上两个防止SQL注入式攻击Function
      ASP

      请不要去掉这个说明。这段注释不会影响执行的速度。=

      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

      Dim strconn,rs

      strconn="Driver={sql server};server=localhost;database=northwind;uid=sa;pwd=sa;"

      Public Function GetEmployees()

       Dim SQL,Rs,Cache

       Set Cache=New Cls_Cache

       Cache.Reloadtime=0.5

       Cache.CacheName="wawa"

       Cache.Name="Employees"

       If Cache.ObjIsEmpty() Then

        Set rs=Server.CreateObject("ADODB.Recordset")

        SQL = "select EmployeeID, LastName, FirstName from employees order by employeeid desc"

        Rs.Open SQL,strconn,1,1

        Cache.value = Rs.GetRows(5)

        Rs.Close:Set Rs=Nothing

       End If

       GetEmployees=Cache.Value

       Set Cache=Nothing

      End Function

      ShowRsArr(GetEmpLoyees)

      %>

      <script>

      function TimeOut(a){

       var c=a-1;

       if(c==0) {

        window.location.href=window.location;

       }else{

        document.all.abc.innerHTML="离缓存结束还有:"+c+"秒";

        window.setTimeout('TimeOut('+c+')',1000);

       }

      }

      </script>

      <body onload="TimeOut('30')">

      <div id="abc"></div> 

      用ASP+Access创建网站RSS格式内容摘要
      ASP错误处理,ASP网站防范黑客技巧,巧用ASP技术保护DHTML源代码,用ASP取出HTML里面的图片地址的函数,ASP实现网页打开任何类型文件都保存,ASP木马Webshell安全解决办案,几招让你的网站免受采集之苦,ASP使用MYSQL数据库全攻略,Ad Rotator 组件参考,在Asp中使用存储过程数值类型值,asp防止同时登陆的问题,使用ASP重启服务器,在ASP程序中实现数据库事务控制,深入理解ASP中FSO的神奇功能,Asp中一些FSO方面的函数,用ASP编程实现网络内容快速查找,ASP实现文件直接下载,Adodb.Stream 组件的使用说明,全国省市县无刷新多级关联菜单,ASP上两个防止SQL注入式攻击Function
      ASP

    • 0
    • 0
    • 0
    • 107
    • 单栏布局 侧栏位置: