cls_Cache.asp
上传用户:szhf331
上传日期:2022-06-22
资源大小:1032k
文件大小:3k
源码类别:

行业应用

开发平台:

JavaScript

  1. <%
  2. Class Cls_Cache 
  3. Rem ==================使用说明==================== 
  4. Rem = 本类模块是动网先锋原创,作者:迷城浪子。如采用本类模块,请不要去掉这个说明。这段注释不会影响执行的速度。 
  5. Rem = 作用:缓存和缓存管理类 
  6. Rem = 公有变量:Reloadtime 过期时间(单位为分钟)缺省值为14400 
  7. Rem = MaxCount 缓存对象的最大值,超过则自动删除使用次数少的对象。缺省值为300 
  8. Rem = CacheName 缓存组的总名称,缺省值为"Dvbbs",如果一个站点中有超过一个缓存组,则需要外部改变这个值。 
  9. Rem = 属性:Name 定义缓存对象名称,只写属性。 
  10. Rem = 属性:value 读取和写入缓存数据。 
  11. Rem = 函数:ObjIsEmpty()判断当前缓存是否过期。 
  12. Rem = 方法:DelCahe(MyCaheName)手工删除一个缓存对象,参数是缓存对象的名称。 
  13. Rem ======================== 
  14. Public Reloadtime,MaxCount,CacheName 
  15. Private LocalCacheName,CacheData,DelCount 
  16. Private Sub Class_Initialize() 
  17. Reloadtime=14400 
  18. CacheName="Edu25175" 
  19. End Sub 
  20. Private Sub SetCache(SetName,NewValue) 
  21. Application.Lock 
  22. Application(SetName) = NewValue 
  23. Application.unLock 
  24. End Sub 
  25. Private Sub makeEmpty(SetName) 
  26. Application.Lock 
  27. Application(SetName) = Empty 
  28. Application.unLock 
  29. End Sub 
  30. Public Property Let Name(ByVal vNewValue) 
  31. LocalCacheName=LCase(vNewValue) 
  32. End Property 
  33. Public Property Let Value(ByVal vNewValue) 
  34. If LocalCacheName<>"" Then 
  35. CacheData=Application(CacheName&"_"&LocalCacheName) 
  36. If IsArray(CacheData) Then 
  37. CacheData(0)=vNewValue 
  38. CacheData(1)=Now() 
  39. Else 
  40. ReDim CacheData(2) 
  41. CacheData(0)=vNewValue 
  42. CacheData(1)=Now() 
  43. End If 
  44. SetCache CacheName&"_"&LocalCacheName,CacheData 
  45. Else 
  46. Err.Raise vbObjectError + 1, "Edu25175CacheServer", " please change the CacheName." 
  47. End If 
  48. End Property 
  49. Public Property Get Value() 
  50. If LocalCacheName<>"" Then 
  51. CacheData=Application(CacheName&"_"&LocalCacheName) 
  52. If IsArray(CacheData) Then 
  53. Value=CacheData(0) 
  54. Else 
  55. Err.Raise vbObjectError + 1, "Edu25175CacheServer", " The CacheData Is Empty." 
  56. End If 
  57. Else 
  58. Err.Raise vbObjectError + 1, "Edu25175CacheServer", " please change the CacheName." 
  59. End If 
  60. End Property 
  61. Public Function ObjIsEmpty() 
  62. ObjIsEmpty=True 
  63. CacheData=Application(CacheName&"_"&LocalCacheName) 
  64. If Not IsArray(CacheData) Then Exit Function 
  65. If Not IsDate(CacheData(1)) Then Exit Function 
  66. If DateDiff("s",CDate(CacheData(1)),Now()) < 60*Reloadtime Then ObjIsEmpty=False 
  67. End Function 
  68. Public Sub DelCahe(MyCaheName) 
  69. makeEmpty(CacheName&"_"&MyCaheName) 
  70. End Sub 
  71. End Class 
  72.  
  73. %>