欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ASP中Cache技术的应用

程序员文章站 2022-10-31 13:49:26
asp从发布至今已经7年了,使用asp技术已经相当成熟,自从微软推出了asp.net之后就逐渐停止了对asp版本的更新。但是由于有很多人仍然习惯使用asp来开发网站,所以,...

asp从发布至今已经7年了,使用asp技术已经相当成熟,自从微软推出了asp.net之后就逐渐停止了对asp版本的更新。但是由于有很多人仍然习惯使用asp来开发网站,所以,再次我将以一个简单的例子来说明在asp中如何使用cache。
  简单的说使用cache基本原理是,把经常需要且获得代价昂贵的数据在内存中持续保存一定时间,以供这些数据可以被直接地全局地访问。例如,有一些数据需要从数据库多个表中查询获得,且几乎每个页面都要调用这些数据。

  这种情况下的最佳实现就是将这部分数据cache起来,在asp中的简单实现就是将这些数据的最终表达形式(例如html流)封装在string中然后存入asp内置对象application中(本文主要讨论的是动态cache,简单的asp 应用就省略)。这样做的好处是,在整个网站中可以全局调用这段html,而且application是存在内存中,所以不用再去查询数据库,从而加快了响应时间并节省了服务器负荷。当然这是以消耗内存为代价的,是一个典型的以空间换时间的实例。

  使用这种方法虽然有很多好处,但是再遇到频繁变化的数据源(数据库)的时候,这种方法就可能不再适用,因为asp application对象有一个缺点,就是不能自动随数据源的变化而变化,或者控制刷新间隔。所以就需要开发人员编程来实现动态cache。当然在程序设计的时候可以在所有进行改变数据源(数据库)操作时,就更新一次appliction。从而使数据源(数据库)始终保持一致。这样做在编程上要考虑的问题会比较多,容易遗漏细节。所以除了特定情况我不推荐使用这种方法。

  我认为在asp中最好的办法是用编程实现定时刷新cache,也就是说给application中储存的设一个过期时间。当然,在asp中application对象没有这样一个expiretime属性。这需要用程序实现。

  code
  asp:default.asp

<%@language=vbscript%>
  <%option explicit%>
  <%response.buffer=true%>
  <!--#include file = "conn.asp"-->
  <!--#include file = "getcache.asp"-->
  <html>
  <head>
  <title>asp cache演示</title>
  <meta http-equiv="content-type" content="text/html; charset=gb2312">
  </head>
  <body>
  <h4>每隔10秒刷新cache:</h4>
  <%
  response.flush
  gethtmlstream
  response.write
  htmlstream
  %>
  </body>
  </html>


  asp:getcache.asp

<%
  const cache_default_interval = 30 '每隔30秒刷新一次cache
  dim htmlstream
  dim isexpires
  isexpires = cacheexpires
  function cacheexpires
  dim strlastupdate
  dim result strlastupdate = application("lastupdate")
  if (strlastupdate = "") or (cache_default_interval < datediff("s", strlastupdate, now)) then
  result = true
  setlastupdatetime
  else
  result = false
  end if
  cacheexpires = result
  end function

sub setlastupdatetime
  application.lock
  application("lastupdate") = cstr(now())
  application.unlock
  end sub

  sub gethtmlstream
  if isexpires then
  updatehtmlstream
  end if
  htmlstream=application("cache_htmlstream")
  end sub

  sub updatehtmlstream
  dim d
  d = fetchhtmlstream
  application.lock
  application("cache_htmlstream") = d
  application.unlock
  end sub

  function fetchhtmlstream
  dim rs ,strsql, strhtml
  set rs = createobject("adodb.recordset")
  strsql = "select categoryid , categoryname from categories"
  rs.open strsql, strconn,adopenforwardonly,adlockreadonly
  strhtml = strhtml & "<select name=""slt_search"">"
  while (not rs.eof)
  strhtml = strhtml & "<option>"
  strhtml = strhtml & rs.fields("categoryname")
  strhtml = strhtml & "</option>" rs.movenext
  wend
  strhtml = strhtml & "</select>"
  rs.close
  set rs = nothing
  fetchhtmlstream = strhtml
  end function
  %>

 

  asp:conn.asp

<!--metadata name="microsoft activex data objects 2.5 library" type="typelib" uuid="{00000205-0000-0010-8000-00aa006d2ea4}"-->
  <%
  dim strconn
  strconn = "provider=sqloledb.1;integrated security=sspi;persist security info=false;initial catalog=northwind"
  %>